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到 PHP 7+ MySQL 5.7 最 佳 组 合 


提供 大 量 开 发 示例 ， 让 你 看 得 懂 、 学 
得 会 、 做 得 出 


于 将 最 实用 的 技巧 融入 到 每 个 案例 中 ， 
教 你 快速 成 为 网 站 应 用 开发 高 手 





源 代码 、 课 件 、 教 学 视频 、 命 令 速 查 手 册 . 
渡 革 大 学 出 版 社 


PHP+MySQL 
动态 网 站 开发 。，。 
从 入 门 到 精通 ( 视频 教学 版 ) 





GQ 





汪 革 大 学 出 版 社 
北京 


内 容 简 介 

本 书 循序 渐进 地 介绍 了 PHP 7 开发 动态 网 站 的 主要 知识 和 技能 ， 提 供 了 大 量 的 PHP 和 MySQL 的 应 用 实 
例 供 读者 实践 。 每 一 章 都 清晰 地 讲述 了 代码 作用 及 其 编写 思路 ， 使 读者 能 在 最 短 时 间 内 迅速 掌握 PHP 的 应 用 
开发 技能 。 

全 书 共 21 章 ， 分 别 介绍 了 PHP 7 的 基本 概念 、PHP 服务 器 环境 配置 、PHP 的 基本 语法 、PHP 的 语言 结 
构 、 字 符 串 和 正则 表达 式 、 数 组 、 时 间 和 日 期 、 面 向 对 象 、 错 误 处 理 和 异常 处 理 、PHP 与 Web 页 面 交互 、 文 
件 与 目录 操作 、 图 形 图 像 处 理 、Cookie 与 会 话 管理 、MySQL 数据 库 基础 、 数 据 表 的 基本 操作 、 数 据 的 基本 操 
作 、 数 据 库 的 备份 与 还 原 、PHP 操作 MySQL 数据 库 等 ， 最 后 通过 两 个 综合 案例 ， 使 读者 进一步 巩固 所 学 的 
知识 ， 提 高 综合 实战 能 力 。 

本 书 适合 PHP 和 MySQL 的 初学 者 ， 以 及 广大 网 站 开发 人 员 ， 也 可 供 高 等 院 校 和 培训 学 校 相关 专业 的 师 
生 参 考 。 


本 书 封面 贴 有 清华 大 学 出 版 社 防伪 标签 ， 无 标签 者 不 得 销售 
版 权 所 有 ， 侵 权 必 究 。 侵 权 举报 电话 : 010-62782989 13701121933 
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PHP+MySQL 的 组 合 是 目前 世界 上 最 为 流行 的 Web 开发 工具 。 由 于 大 型 互联 网 站 广泛 使 
这 种 开发 技术 ， 目 前 学 习 和 关注 PHP+MySQL 的 人 越 来 越 多 ， 本 书 作 者 针对 PHP+MySQL 
的 初学 者 ， 从 通俗 易 懂 、 容 易 入 门 和 案例 实用 的 目标 出 发 ， 组 织 有 丰富 经 验 的 开发 人 员 ， 编 写 
了 这 本 PHP+MySQL 动态 网 站 开发 的 教材 。 

本 书 内 容 


全 书 共 21 章 ， 主 要 介绍 了 PHP 7 的 基本 概念 、PHP 服务 器 环境 配置 、PHP 的 基本 语法 、 
PHP 的 语言 结构 、 字 符 串 和 正则 表达 式 、 数 组 、 时 间 和 日 期 、 面 向 对 象 、 错 误 处 理 和 异常 处 
理 、PHP 与 Web 页 面 交 互 、 文 件 与 目录 操作 、 图 形 图 像 处 理 、Cookie 与 会 话 管理 、MySQL 
数据 库 基础 、 数 据 表 的 基本 操作 、 数 据 的 基本 操作 、 数 据 库 的 备份 与 还 原 、PHP 操作 MySQL 
数据 库 等 ， 最 后 通过 两 个 综合 案例 ， 使 读者 进一步 巩固 所 学 的 知识 ， 提 高 综合 实战 能 力 。 
本 书 特色 
@ 知识 全 面 : 涵盖 了 所 有 PHP+MySQL 开发 的 知识 点 ， 读 者 可 以 由 浅 入 深 地 掌握 
PHP+MySQL 动态 网 站 开发 技术 。 

@ 图 文 并 诚 : 注重 操作 ， 在 介绍 案例 的 过 程 中 ， 每 一 个 操作 均 有 对 应 的 插图 。 这 种 图 文 
结合 的 方式 使 读者 在 学 习 过 程 中 能 够 直观 、 清 晰 地 看 到 操作 的 过 程 以 及 效果 ， 便 于 更 
快 地 理解 和 掌握 。 

@ 易学 易 用 : 颠覆 传统 “看 ” 书 的 观念 ， 变 成 一 本 能 “操作 ”的 图 书 。 

@ 案例 丰富 : 把 知识 点 融 汇 于 系统 的 案例 实 训 当 中 , 并 且 结合 经 典 案例 进行 讲解 和 拓展 。 

进而 达到 “ 知 其 然 ， 并 知 其 所 以 然 ”的 效果 。 

@ 提示 技巧 本 书 对 读者 在 学 习 过 程 中 可 能 会 遇 到 的 疑难 问题 以 “提示 ”和 “技巧 ”的 

形式 进行 了 说 明 ， 以 免 读者 在 学 习 的 过 程 中 走 弯路 。 

@ 技术 实用 : 本 书 所 有 案例 都 是 模仿 现实 网 站 开发 而 设计 , 通过 本 书 最 后 两 个 综合 案例 ， 

让 读者 快速 创建 动态 的 PHP+MySQL 企业 网 站 。 

读者 对 象 


本 书 是 一 本 完整 介绍 PHP+MySQL 动态 网 站 开发 技术 的 教程 ， 内 容 丰 富 ， 条 理 清晰 ， 实 用 性 
强 ， 适 合 如 下 读者 学 习 使 用 : 

@ 对 PHP+MySQL 动态 网 站 制作 有 兴趣 的 初学 者 ， 可 以 快速 入 门 。 

@ 对 PHP 语言 感 兴趣 的 初学 者 ， 可 以 快速 掌握 PHP 语言 开发 基本 技巧 。 

@ MySQL 数据 库 的 初学 者 ， 可 以 快速 掌握 MySQL 的 基本 操作 方法 。 

@ PHP+MySQL 架构 的 Web 系统 开发 人 员 。 
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PHP 的 发 展 
1.1.1 PHP 的 概念 .. 
1.1.2 PHP 的 发 展 历程 .…… 
1.1.3 PHP 语言 的 优势 … 
PHP 的 应 用 领域 
PHP 7 的 新 特点 .…… 
PHP 常用 开发 工具 . 
1.4.1 PHP 代码 开发 工具 … 
1.4.2 网 页 设计 工具 …. 
1.4.3 ”文本 编辑 工具 ..… 
高 手 私房 菜 . 
经 典 习题 ….………… 
泥 置 PHP7 服务器 环境 9 


PHP 服务 器 概述 
安装 PHP 7 前 的 准备 工作 
2.2.1 软 硬 件 环 境 .…………………. 
2.2.2 ”获取 PHP 7 安装 资源 包 
PHP 7+Apache 服务 器 的 环境 搭建 .. 
2.3.1 Apache 简 从 ,smivisivns 
2.3.2 关闭 原 有 的 网 站 服务 器 
2.3.3 ”安装 Apache .pe 
2.3.4 将 PHP 与 Apache 建立 关联 
PHP 环境 的 集成 软件 
实战 演练 一 一 我 的 第 一 个 PHP 程序 










































PHP 标识 符 .… 
3.1.1 短 风 格 .. 
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3.1.2 script 风格 
3.1.3 ASP 风格 .. 
3.2 ”编码 规范 ……………… 
3.2.1 什么 是 编码 规 
3.2.2 PHP 中 的 编码 规范 … 
33 常量 seoavsaowsoaa 
3.3.1 声明 和 使 用 常量 
3.3.2 内置 常量 .… 
3 二 变量 nanaaas 
3.4.1 PHP 中 的 变量 声明 
3.4.2 可 变 变 量 与 变量 的 引用 …. 
3.4.3 ”变量 作用 域 (variable scope) 
3.4.4 变量 的 销毁 .… 
3.5 数据 的 类 型 
3.5.1 什么 是 类 型 
3.5.2 ” 整 型 (integer) .…. 
3.5.3” 浮 点 型 (float 或 double) 
3.5.4 布尔 型 (boolean) .………. 
3.5.5 ”字符 串 型 (string) 
3.5.6 数组 型 (array) 
3.5.7 ”对象 型 (object) .. 
3.5.8 NULL 型 .… 
3.5.9 ”资源 类 型 (resource) .… 
3.5.10 ”数据 类 型 之 间 的 相互 转换 .. 
标量 类 型 的 声明 .. 
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4.2.5 对 函数 的 引用 .…… 
4.2.6 对 函数 取消 引用 
包含 文件 
4.3.1 require 和 include 











4.3.2 include once 和 require_once … 
条 件 控制 结构 …. 
4.5.1 单一 条 件 分 支 结 构 〈 认 语句 ) 
4.5.2 双向 条 件 分 支 结构 〈 证 ..else 语句 ).… 
4.5.3 多 向 条 件 分 支 结构 〈elseif 语 句 ) … 
4.5.4 多 向 条 件 分 支 结构 〈switch 语句 ) .… i 
循环 控制 结构 ……………… .60 
4.6.1 ”while 循环 语句 
4.6.2 do...while 循环 语句 . 
4.6.3 for 循环 语句 ..….……. 
4.6.4 ”foreach 循环 语句 
4.6.5 流程 控制 的 另 一 种 书写 格式 
4.6.6 ”使 用 break/continue 语句 跳出 循环 
实战 演练 1 一 条件 分 支 结构 综合 应 用 
实战 演练 2 一 一 循环 控制 结构 综合 应 用 
经 典 习题 …….… 
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5.3.4 清理 字符 串 中 的 空格 
5.3.5 字符 串 的 切 分 与 组 合 …… 
5.3.6 ”字符 串 子 串 的 截取 



















5.3.7 ”字符 串 子 串 替换 .. ws 
5.3.8 ”字符 串 查 找 .…… i 
5.3.9 大 小 写 转换 . we 
什么 是 正则 表达 式 .…. .80 
正则 表达 式 语 法 规则 .…. 80 
实战 演练 一 一 创建 酒店 系统 在 线 订 房 表 





PHP 数组 


什么 是 数组 ……………… 
数组 的 类 型 
6.2.1 数字 索引 数组 .. 
6.2.2 ”关联 索引 数组 …… 
PHP 常量 数组 .… 

























数组 构造 …… 

6.4.1 一 维 数组 . 93 
6.4.2 ”多 维 数组. 93 
遍历 数组 ….……… ,二 


6.5.1 遍历 一 维 数字 索引 数组 .… 
6.5.2 ”遍历 一 维 联合 索引 数组 … 
6.5.3 ”遍历 多 维 数组 .ee。 
数组 排序 

6.6.1 一 维 数 组 排序 .. 
6.6.2 多 维 数 组 排序 
字符 串 与 数组 的 转换 
向 数组 中 添加 和 删除 元 素 . 
6.8.1 向 数组 中 添加 元 素 . 
6.8.2 ”从 数组 中 删除 元 素 . 
查询 数组 中 指定 元 素 . 
统计 数组 元 素 个 数 … 
删除 数组 中 的 重复 元 素 ……… 
调换 数组 中 的 键 值 和 元 素 值 
实战 演练 一 一 数组 的 序列 化 
高 手 私房 菜 . 
经 典 习题 
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系统 时 区 设置 .…… 
7.1.1 时 区 划分 .…. 
7.1.2 时 区 设置 
PHP 日 期 和 时 间 函 数 … 
7.2.1 关于 UNIX 时 间 截 
7.2.2 ”获取 当前 时 间 戳 

7.2.3 ”获取 当前 日 期 和 时 间 .. 
7.2.4 ”使 用 时 间 戳 获取 日 期 信息 ……. 
7.2.5 检验 日 期 的 有 效 性 .eseeeeeeeseeees 
7.2.6 ”输出 格式 化 时 间 戳 的 日 期 和 时 间 
7.2.7 ”显示 本 地 化 的 日 期 和 时 间 … 
7.2.8 将 日 期 和 时 间 解 析 为 UNIX 时 间 戳 . 
7.2.9 日 期 和 时 间 在 PHP 和 MySQL 数据 格式 之 间 的 转换 
实战 演练 1 一 一 比较 两 个 时 间 的 大 小 
实战 演练 2 一 一 实现 倒计时 功能 … 
高 手 私房 菜 
经 典 习 题 
面向 对 象 编程 .. 


类 和 对 象 的 介绍 .… 
PHP 中 类 的 操作 … 
8.2.1 类 的 声明 . 
8.2.2 成员 属性 .…. 
8.2.3 成 员 方法 
8.2.4 类 的 实例 化 . 
8.2.5 访问 类 中 的 成 员 属性 和 方法 
构造 方法 和 析 构 方法 .…. 
访问 方法 
类 的 继承 .……. 
高 级 特性 … 
8.6.1 静态 属性 和 方法 
8.6.2 final 类 和 方法 




















































8.8.1 通过 继承 实现 多 态 …… 
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常见 的 错误 和 异常 
错误 处 理 


9.2.1 php.ini 中 的 错误 处 理 机 制 . 
9.2.2 应 用 DIE 语句 调试 
9.2.3 自 定义 错误 和 错误 触发 器 
9.2.4 ”错误 记录 
后 第 外 巴 ni 
9.3.1 异常 的 基本 处 理 方法 
9.3.2” 自 定义 的 异常 处 理 器 
9.3.3 ”处 理 多 个 异常 ….…. 
9.3.4 ”设置 顶 层 异 常 处 理 器 
实战 演练 一 一 处 理 异常 或 错误 
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使 用 动态 内 容 . 
表单 与 PHP .… 
表单 设计 
10.3.1 表单 基本 结构 … 
10.3.2 文本 框 .. 
10.3.3 ”选项 框 .. 
10.3.4 单 选 按钮..…. 
10.3.5 下拉 列表 .… 
10.3.6 重 置 按钮 ... 
10.3.7 ”提交 按钮 
传递 数据 的 两 种 方法 .. 
10.4.1 用 POST 方式 传递 数据 .…. 
10.4.2 用 GET 方式 传递 数据 
PHP 获取 表单 传递 数据 的 方法 
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第 1 章 初 识 PHP 


在 学 习 PHP 之 前 ， 读 者 需要 了 解 PHP 的 基本 概念 、PHP 的 特点 、PHP 开发 常用 工具 等 知识 ， 
通过 本 章 的 学 习 ， 读 者 可 对 PHP 有 一 个 初步 的 了 解 。 本 章 将 主要 讲述 入 门 PHP 的 基本 知识 。 
本 章 学 习 目标 
@ 了解 PHP 的 来 龙 去 脉 
@ 
@ 





熟悉 PHP 的 应 用 领域 
熟悉 PHP7 新 特点 
掌握 PHP 常用 开发 工具 


1.1 PHP 的 发 展 
PHP 语言 和 其 他 语言 有 什么 不 同 呢 ? 对 于 此 问题 ， 首 先 需要 了 解 PHP 的 概念 和 发 展 历程 。 
1.1.1 PHP 的 概念 


PHP 全 名 为 Personal Home Page， 是 英文 Hypertext Preprocessor (超级 文本 预 处 理 语言 ) 的 缩 
写 。P 是 一 种 HTML 内 嵌 式 的 语言 ， 在 服务 器 端 执行 的 嵌入 HTML 文档 的 脚本 语言 ， 语 言 风 格 类 
似 于 C 语言 ， 被 广泛 用 于 动态 网 站 的 制作 中 。PHP 语言 借鉴 了 C 和 Java 等 语言 的 部 分 语法 ， 并 有 
自己 独特 的 特性 ， 使 Web 开发 者 能 够 快速 地 编写 动态 生成 页 面 的 脚本 。 对 于 初学 者 而 言 ，PHP 的 
优势 是 可 以 快速 入 门 。 

与 其 他 的 编程 语言 相 比 ，PHP 是 将 程序 嵌入 到 HTML 文档 中 去 执行 ， 执 行 效率 比 完全 生成 
HTML 标记 的 方式 要 高 许多 。PHP 还 可 以 执行 编译 后 的 代码 ， 编 译 可 以 起 到 加 密 和 优化 代码 运行 
的 作用 ， 使 代码 运行 得 更 快 。 另 外 ，PHP 具有 非常 强大 的 功能 ， 所 有 的 CGI 功能 PHP 都 能 实现 ， 
而 且 儿 乎 支持 所 有 流行 的 数据 库 和 操作 系统 .。 最 重要 的 是 , PHP 还 可 以 用 C、C++ 进 行程 序 的 扩展 。 


1.1.2 PHP 的 发 展 历程 


目前 ， 市面 上 有 很 多 Web 开发 语言 ， 其 中 PHP 是 比较 出 众 的 一 种 Web 开发 语言 。 与 其 他 脚 
本 语言 不 同 , PHP 是 通过 全 世界 免费 代码 开发 者 共同 的 努力 , 才 发 展 到 今天 的 规模 。 要 想 了 解 PHP， 
首先 从 它 的 发 展 历程 开始 。 

在 1994 年 ，Rasmus Lerdorf 首次 设计 出 了 PHP 程序 设计 语言 。1995 年 6 月 ，Rasmus Lerdorf 
在 Usenet 新 闻 组 comp.infosystems.www.authoring.cgi 上 发 布 了 PHP 1.0 声明 。 这 个 早期 版 本 提供 了 
访客 留言 本 、 访 客 计 数 器 等 简单 的 功能 。 

1995 年 ， 第 二 版 PHP 问 市 ， 定 名 为 PHP/FI (Form Interpreter) 。 在 这 一 版 本 中 加 入 了 可 以 处 
理 更 复杂 的 嵌入 式 标签 语言 的 解析 程序 ， 同 时 加 入 了 对 数据 库 MySQL 的 支持 。 自 此 黄 定 了 PHP 
在 动态 网 页 开发 上 的 影响 力 。 自 从 PHP 加 入 了 这 些 强大 的 功能 ， 它 的 使 用 量 猛 增 。 据 初步 统计 ， 
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在 1996 年 底 ， 有 15 000 个 Web 网 站 使 用 了 PHP/FI; 而 在 1997 年 中 期 ， 这 一 数字 超过 了 50 000。 

前 两 个 版 本 的 成 功 ， 让 PHP 的 设计 者 和 使 用 者 对 PHP 的 未 来 充满 了 信心 。 在 1997 年 ，PHP 
开发 小 组 又 加 入 了 Zeev Suraski 及 Andi Gutmans， 他 们 自愿 重新 编写 了 底层 的 解析 引擎 ， 另 外 ,还 
有 很 多 人 员 也 自愿 加 入 了 PHP 其 他 部 分 的 工作 ， 从 此 PHP 成 为 了 真正 意义 上 的 开源 项 目 。 

1998 年 6 月 发 布 了 PHP 3.0。 在 这 一 版 本 中 ，PHP 可 以 跟 Apache 服务 器 紧密 地 结合 ， 再 加 上 
它 的 不 断 更 新 及 加 入 新 的 功能 ; 并 且 它 几乎 支持 所 有 主流 与 非 主流 数据 库 ; 而 且 拥 有 非常 高 的 执行 
效率 ， 这 些 优 势 使 1999 年 使 用 PHP 的 网 站 超过 了 150 000 个 。 

经 过 3 个 版 本 的 演化 ，PHP 已 经 变 成 一 个 非常 强大 的 Web 开发 语言 。 这 种 语言 非常 易 用 ， 而 
且 它 拥有 一 个 强大 的 类 库 ， 类 库 的 命名 规则 也 十 分 规范 ,使 用 者 就 算 对 一 些 函数 的 功能 不 了 解 ， 也 
可 以 通过 函数 名 猜 出 来 。PHP 程序 可 以 直接 使 用 HTML 编辑 器 来 处 理 ， 因 此 ，PHP 变 得 非常 流行 ， 
有 很 多 大 的 门户 网 站 都 使 用 了 PHP 作为 自己 的 Web 开发 语言 ， 例 如 新 浪 网 等 。 

在 2000 年 5 月 推出 了 划时代 的 版 本 PHP 4。PHP 4 使 用 了 一 种 “编译 -执行 ”模式 ， 其 核心 引 
擎 更 加 优越 ， 提 供 了 更 高 的 性 能 ， 而 且 还 包含 其 他 一 些 关键 功能 ， 比 如 支持 更 多 的 Web 服务 器 、 
HTTP Sessions 支持 、 输 出 缓存 、 更 安全 地 处 理 用 户 输入 的 方法 以 及 一 些 新 的 语言 结构 。 

2004 年 7 月 ,PHP 5 发 布 。 该 版 本 以 Zend 引擎 [为 引擎 ,并 且 加 入 了 新 功能 如 PHP Data Objects 

(PDO) 。PHP 5 版 本 强化 更 多 的 功能 。 首 先 ， 完 全 实现 面向 对 象 ， 提 供 名 为 PHP 兼容 模式 的 功 
能 。 其 次 是 XML 功能 ，PHP 5 版 本 支持 可 直观 地 访问 XML 数据 、 名 为 SimpleXML 的 XML 处 理 
界面 。 同 时 还 强化 了 XMLWeb 服务 支持 ， 而 且 标准 支持 SOAP 扩展 模块 。 数 据 库 方面 ，PHP 新 版 
本 提供 旨 在 访问 MySQL 的 新 界面 一 一 MySQL。 除 此 前 的 界面 外 ， 还 可 以 使 用 面向 对 象 界面 和 预 
处 理 语句 (Prepared Statement) 等 MySQL 的 新 功能 .另外 ,PHP 5 上 还 拥 绑 有 小 容量 RDBMS-SQLite. 

2015 年 6 月 ， 第 一 版 PHP 7 发 布 。 这 是 十 年 来 的 首次 大 改版 ， 最 大 特色 是 在 性 能 上 的 大 突破 ， 
能 比 前 一 版 PHP 5 快 上 一 倍 。 

PHP 目前 较 新 版 本 是 PHP 7， 它 在 PHP 5 基础 上 做 了 进一步 的 改进 ， 功 能 更 强大 ， 执 行 效率 
更 高 ， 性 能 更 强悍 。 本 书 将 以 PHP 7 版 本 来 讲解 PHP 的 实用 技能 。 


1.1.3 ”PHP 语言 的 优势 


PHP 能 够 迅速 发 展 ， 并 得 到 广大 使 用 者 的 喜爱 ， 主 要 原因 是 PHP 不 仅 有 一 般 脚 本 所 具有 的 功 
能 ， 而 且 有 它 自身 的 优势 ， 具 体 特点 如 下 。 


@ 源 代 码 完 全 开放 : 事实 上 ， 所 有 的 PHP 源 代码 都 可 以 获得 。 读 者 可 以 通过 Internet 获得 
需要 的 源 代码 ， 快 速 修改 并 利用 。 

@ 完全 免费 : 和 其 他 技术 相 比 ，PHP 本 身 是 免费 的 。 读 者 使 用 PHP 进行 Web 开发 无 须 支付 
任何 费用 。 

@ ”语法 结构 简单 : 因为 PHP 结合 了 C 语言 和 了 Perl 语言 的 特色 ,编写 简单 ,方便 易 懂 。 可 以 
嵌入 于 HTML 语言 ， 实 用 性 强 ， 更 适合 初学 者 。 

@ 。 跨 平 台 性 强 : 由 于 PHP 是 运行 在 服务 器 端的 脚本 ， 可 以 运行 在 UNIX、Linux 和 Windows 
下 。 

@ 效率 高 PHP 消耗 相当 少 的 系统 资源 ， 并 且 程 序 开 发 快 ， 运行 快 。 

@ ”强大 的 数据 库 支持 : 支持 目前 所 有 的 主流 和 非 主流 数据 库 , 使 PHP 的 应 用 对 象 非 常 广泛 。 

@ 面向 对 象 : 在 PHP7 中 ,面向 对 象 方面 都 有 了 很 大 的 改进 ， 现 在 PHP 完全 可 以 用 来 开发 
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大 型 商业 程序 。 


1.2 PHP 的 应 用 领域 


初学 者 也 许 会 有 疑问 ，PHP 到 底 能 干什么 呢 ? 下 面 将 介绍 PHP 的 应 用 领域 。 

PHP 在 Web 开发 方面 的 功能 非常 强大 ， 可 以 完成 一 款 服务 器 所 能 完成 的 工作 。 有 了 PHP, 用 
户 可 以 轻松 地 进行 Web 开发 。 下 面 来 具体 学 习 一 下 PHP 的 应 用 领域 ， 例 如 生成 动态 网 页 、 收 集 表 
单数 据 和 发 送 或 接受 Cookies 等 。 

PHP 主要 应 用 于 以 下 3 个 领域 。 


1. 服务 端 脚本 


PHP 最 主要 的 应 用 领域 是 服务 器 端 脚 本 。 服 务 器 脚本 运行 需要 具备 3 项 配置 : PHP 解析 器 、 
Web 浏览 器 和 Web 服务 器 。 在 Web 服务 器 运行 时 , 安装 并 配置 PHP, 然后 用 Web 浏览 器 访问 PHP 
程序 输出 。 在 学 习 的 过 程 中 ， 读 者 只 要 在 本 机 上 配置 Web 服务 器 ， 即 可 浏览 制作 的 PHP 页 面 。 

2. 命令 行 脚 本 

命令 行 脚本 和 服务 端 脚本 不 同 ， 编 写 的 命令 行 脚本 并 不 需要 任何 服务 器 或 浏览 器 运行 ， 在 命 
令 行 脚本 模式 下 ， 只 需要 PHP 解析 器 执行 即 可 。 这 些 脚 本 在 Windows 和 Linux 平台 下 作为 日 常 运 
行 脚本 ， 也 可 以 用 来 处 理 简单 的 文本 。 

3. 编写 桌面 应 用 程序 

PHP 在 桌面 应 用 程序 的 开发 中 并 不 常用 ， 但 是 如 果 用 户 希 望 在 客户 端 应 用 程序 中 使 用 PHP 编 
写 图 形 界面 应 用 程序 ， 可 以 通过 PHP-GTK 来 编写 。PHP-GTK 是 PHP 的 扩展 ， 并 不 包含 在 标准 的 
开发 包 中 ， 开 发 用 户 需 要 单独 编译 它 。 


1.3 PHP 7 的 新 特点 


PHP 7 是 PHP 编程 语言 的 一 个 主要 版 本 ， 是 开发 Web 应 用 程序 的 一 次 革命 ， 可 开发 和 交付 移 
动 企业 和 云 应 用 。 此 版 本 被 认为 是 PHP 5 后 最 重要 的 变化 。 
和 早期 版 本 相 比 ，PHP 7 有 以 下 新 的 特点 。 


1. 标量 类 型 声明 


PHP 7 增加 了 对 返回 类 型 声明 的 支持 。 返 回 类 型 声明 指明 了 函数 返回 值 的 类 型 。 可 用 的 类 型 
与 参数 声明 中 可 用 的 类 型 相同 。 例 如 以 下 代码 : 


<?php 

function arraysSum(array ...$arrays): array 

{ 

return array map (function (array $array): int { 
return array_sum($array); 

}, $arrays); 

} 





























“3. 
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以 上 例子 会 输出 : 
Rrray 

[0] => 6 

[1] => 15 

[2] => 24 


2. null 合并 运算 符 

新 增 了 null 合并 运算 符 “? ? ”， 它 可 以 替换 三 元 表达 式 和 isset0。 例 如 以 下 代码 : 
Sa = isset($ GET['a']) ? $ GET['a'] : 1; 

可 以 用 null 合并 运算 符 蔡 换 如 下 : 

$a = $ GET['a'] ?? 1; 


这 两 个 语句 的 含义 都 是 : 如 果 变 量 a 存在 且 值 不 为 NULL， 它 就 会 返回 自身 的 值 ， 否 则 返回 它 
的 第 二 个 操作 数 。 可 见 ， 新 增 的 2? 运算 符 可 以 简化 判断 语句 。 

3. 组 合 比较 符 

组 合 比较 符 <=> 用 于 比较 两 个 表达 式 。 例 如 $a<=>$b， 表 示 当 $a 大 于 、 等 于 或 小 于 $b 时 它 分 别 
返回 1、0 或 -1。 例 如 以 下 代码 ; 


<?php 

// 整 型 举例 

echo 1 <=> 1; // 输 出 0 
echo 1 <=> 2; // 输 出 -1 
echo 2 <=> 1; // 输出 1 

// 浮 点 型 举例 

echo 5.5 <=> 5.5 // 输 出 0 
echo 5.5 <=> 7.0; // 输 出 -1 
echo 7.0 <=> 5.5; // 输 出 1 
// 字符 串 型 举例 

echo "a" <=> "a"; // 输 出 0 
echo "a" <=> "b"; // 输 出 -1 
echo "bm <=> "a"; // 输 出 1 
2> 


4. 通过 define() 定义 常量 数组 
对 于 常量 数组 ， 可 以 使 用 define0) 定 义 ， 例 如 以 下 代码 : 


<?php 

define('PERSON', ['xiaoming', 'xiaoli', 'xiaolan']); 
echo PERSON[1]; // 输出 "xiaoli" 

?> 
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5. 匿名 类 

现在 支持 通过 new class 来 实例 化 一 个 匿名 类 ， 这 可 以 用 来 替代 一 些 “ 用 后 即 焚 ”的 完整 
6. 支持 Unicode 字符 格式 

PHP 7 支持 任何 有 效 的 codepoint 编码 ， 输 出 为 UTF-8 编码 格式 的 字符 串 。 例 如 以 下 代码 : 


<?php 
echo "\u{6666}"; 
?> 


在 PHP 7 环境 下 输出 为 : 此 ， 而 在 早期 版 本 中 则 输出 为 : \u{6666} 
7. 更 多 的 Error 变 为 可 捕获 的 Exception 


PHP 7 实现 了 一 个 全 局 的 throwable 接口 ， 原 来 的 Exception 和 部 分 Error 都 实现 了 这 个 接口 
Cinterface) ， 以 接口 的 方式 定义 了 异常 的 继承 结构 。 于 是 ，PHP 7 中 更 多 的 Error 变 为 可 捕获 的 
Exception 返回 给 开发 者 。 如 果 不 进行 捕获 则 为 Error， 如 果 捕 获 就 变 为 一 个 可 在 程序 内 处 理 的 
Exception。 这 些 可 被 捕获 的 Eror 通常 都 是 不 会 对 程序 造成 致命 伤害 的 Error， 例 如 函数 不 存在 。 
PHP 7 进一步 方便 开发 者 处 理 ， 让 开发 者 对 程序 的 掌控 能 力 更 强 。 因 为 在 默认 情况 下 ，Error 会 直 
接 导致 程序 中 断 ， 而 PHP 7 则 提供 捕获 并 且 处 理 的 能 力 ， 让 程序 继续 执行 下 去 ， 为 程序 员 提 供 更 
灵活 的 选择 。 

例如 ， 执 行 一 个 不 确定 是 否 存 在 的 函数 ，PHP 5 兼容 的 做 法 是 在 函数 被 调用 之 前 追加 的 判断 
function_exist， 而 PHP 7 则 支持 捕获 Exception 的 处 理 方式 。 

8. 性 能 大 幅度 提升 


PHP7 较 PHP 5 相 比 ,速度 快 2 倍 以 上 。 另 外 ，PHP 7 降低 内 存 消 耗 ， 优 化 后 PHP 7 使 用 较 少 
的 资源 ， 比 PHP 5.6 低 了 50% 的 内 存 消耗 。 同 时 ，PHP 7 也 支持 64 位 架构 机 器 ， 运 算 速 度 更 快 。 
PHP 7 可 以 服务 于 更 多 的 并 发 用 户 ， 无 须 任何 额外 的 硬件 。 


1.4 PHP 常用 开发 工具 


可 以 编写 PHP 代码 的 工具 有 很 多 ,目前 常见 的 有 Dreamweaver、PHPEdit、PHPed 和 Frontpage 
等 ， 甚 至 用 Word 和 记事 本 等 常用 工具 也 可 以 编写 源 代码 。 
1.4.1 PHP 代码 开发 工具 

常见 的 PHP 代码 开发 工具 有 PHPEdit、gPHPedit、phpDesigner 和 Zend Studio。 

1. PHPEdit 


PHPEdit 是 Windows 下 一 款 优秀 的 PHP 脚本 IDE (集成 开发 环境 ) 。 该 软件 为 快速 、 便 捷 地 
开发 PHP 脚本 提供 了 多 种 工具 ， 其 功能 包括 : 语法 关键 词 高 亮 ， 代 码 提示 、 浏 览 ， 集 成 PHP 调试 
工具 ， 帮 助 生成 器 ， 自 定义 快捷 方式 ，150 多 个 脚本 命令 ,键盘 模板 ， 报 告 生成 器 ， 快 速 标 记 和 插 
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件 等 。 

2. gPHPedit 

gPHPedit 是 Linux 下 十 分 流行 的 免费 的 PHP 编辑 器 , 它 小 巧 而 功能 强大 。 它 以 Linux 下 的 gedit 
文本 编辑 器 为 基础 ， 是 专门 用 于 编辑 PHP 和 html 的 编辑 器 。 它 可 以 显著 表示 PHP、html、css 以 
及 SQL 语句 。 在 编写 过 程 中 提供 函数 列表 参考 、 函 数 参数 参考 、 搜 索 和 检测 编程 语法 等 。 总 之 ， 
gPHPedit 是 一 款 完全 免费 的 优秀 的 PHP 编辑 器 。 

3. PhpDesigner 

PhpDesigner 是 一 款 功能 强大 的 、 运 行 高 效 的、 优秀 的 PHP 编辑 平台 。 它 集合 了 PHP、xhtml、 
JavaScript、css 等 基于 Web 开发 的 综合 Web 应 用 开发 平台 。 它 能 够 自动 捕获 代码 文件 中 的 class、 
function、varibles 等 编程 元 素 ， 并 加 以 整理 ， 在 编程 过 程 中 给 予 提示 。 除 此 以 外 ， 它 还 兼容 了 流行 
的 各 种 类 库 和 框架 的 协同 工作 ， 比 如 JavaScript 的 jQuery 库 、YUI 库 、prototype 库 等 ， 又 比如 PHP 
流行 的 zend framework 框架 、symfony 框架 、cakephp 框架 、yii 框架 等 。 此 外 ， 它 还 拥有 xdebug、 
svn 版 本 管理 等 工具 。 可 以 说 它 是 独立 于 eclipse 之 外 的 ， 集 合 了 PHP 开发 需求 之 大 成 的 又 一 款 优 
秀 的 平台 。 

4. Zend Studio 

Zend Studio 是 由 zend 科技 开发 的 一 个 针对 PHP 的 全 面 开发 平台 。 这 个 IDE 融合 了 zend server 
和 zend framework， 并 且 融 合 了 Eclipse 开发 环境 。Eclipse 是 最 早 适 用 于 Java 的 IDE 环境 ， 但 是 
由 于 其 优良 的 特性 和 对 PHP 的 支持 ， 成 为 很 有 影响 力 的 PHP 开发 工具 。 现 在 ， 最 新 的 Eclipse PHP 
开发 环境 为 Eclipse PDT 2.2.0 版 本 ， 它 拥有 支持 Windows、Linux 和 Mac 系统 的 软件 包 ， 可 以 说 
它 拥有 比较 完备 的 体系 。 它 是 一 款 收费 的 工具 。 


1.4.2 网 页 设计 工具 

下 面 介绍 两 种 常见 的 网 页 设计 工具 。 

1. Dreamweaver 

Dreamweaver 是 网 页 制作 “三 剑客 ”之 一 ， 其 功能 更 多 体现 在 对 Web 页 面 HTML 的 设计 上 。 
随 着 Web 语言 的 发 展 ，Dreamwaver 的 功能 早已 不 再 仅 限 于 网 页 设计 的 方面 ， 它 更 多 地 支持 各 种 
Web 应 用 流行 的 前 后 台 技 术 的 综合 运用 。Dreamwaever 对 PHP 的 支持 十 分 到 位 ， 它 不 但 对 PHP 的 
不 同方 面 进 行 清晰 地 表示 ， 并 且 给 予 足够 的 编程 提示 ， 使 编程 过 程 相当 流畅 。 


2. FrontPage 


FrontPage 是 微软 公司 出 品 的 一 款 网 页 制作 入 门 级 软件 。FrontPage 使 用 方便 简单 ， 会 用 Word 
就 能 做 网 页 ， 所 见 即 所 得 是 其 特点 ， 该 软件 结合 了 设计 、 拆 分 、 代 码 和 预览 4 种 模式 。 


1.4.3 文本 编辑 工具 
常见 的 文本 编辑 工具 有 很 多 ， 包 括 UitraEdit 和 记事 本 等 。 
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1. UitraEdit 

UltraEdit 是 一 套 功能 强大 的 文本 编辑 器 ， 可 以 编辑 文本 、 十 六 进 制 、ASCII 码 ， 完 全 可 以 取 
代 记 事 本 如果 电 脑 配 置 足够 强大 ) ， 内 建英 文 单词 检查 、C++ 及 VB 指令 突显 ， 可 同时 编辑 多 
个 文件 ， 而 且 即 使 开启 很 大 的 文件 速度 也 不 会 慢 。 软 件 附 有 HTML 标签 颜色 显示 、 搜 寻 替 换 以 及 
无 限制 的 还 原 功 能 ， 一 般 用 其 来 修改 EXE 或 DLL 文件 。UitraEdit 是 能 够 满足 用 户 一 切 编辑 需要 
的 编辑 器 。 

2. 记事 本 

记事 本 是 Windows 系统 自 带 的 文本 编辑 工具 。 它 具备 最 基本 的 文本 编辑 功能 ， 体 积 小 巧 ， 启 
动 快 ， 占 用 内 存 少 ， 容 易 使 用 。 记 事 本 主 窗口 如 图 1-1 所 示 。 


壬 一 -如 [一 -区 司 











图 1-1 记事 本 主 窗口 


在 使 用 记事 本 编辑 PHP 文档 的 过 程 中 ， 需 要 注意 保存 方法 和 技巧 。 在 【另存 为 】 对 话 框 中 输 
入 文件 名 称 ， 后 级 名 为 .php。 另 外 ， 将 【保存 类 型 】 设 置 为 【所 有 文件 】 即 可 ， 如 图 1-2 所 示 。 
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图 1-2 【另存 为 】 对 话 框 
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1.5 ”高 手 私房 菜 


技巧 1: 如 何 快速 了 解 PHP 的 应 用 技术 ? 

在 学 习 的 过 程 中 ， 用 户 可 以 随时 查阅 PHP 的 应 用 情况 。 启 动 正 浏览 器 ， 在 地 址 栏 中 输入 
http://www.baidu.com， 打 开 搜 索引 擎 ， 输 入 需要 搜索 的 内 容 即 可 了 解 相关 技术 。 

技巧 2: 如 何 选择 PHP 开发 软件 ? 

无 论 是 哪个 开发 工具 , 在 PHP 的 开发 过 程 中 ， 都 要 有 对 PHP 的 语法 和 数据 进行 分 色 表 示 的 能 
力 ， 以 方便 开发 者 编写 程序 。 进 一 步 的 功能 是 要 有 对 代码 编写 提示 的 能 力 ， 对 于 PHP 的 数据 类 型 、 
运算 符 、 标 识 、 名 称 等 都 有 提示 功能 。 

那么 多 的 开发 工具 , 选择 一 款 比较 适合 自己 的 即 可 。 就 初学 者 而 言 , 使 用 phpDesigner 比较 好 ， 
它 集合 了 PHP、XHTML、JavaScript、CSS 等 基于 Web 开发 的 综合 Web 应 用 开发 技术 ， 对 于 学 习 
Web 开发 的 初学 者 而 言 ， 随 时 可 以 学 习 相关 的 Web 技术 。 


1.6 经 典 习题 








(1) 查询 PHP 的 应 用 领域 。 
(2) 在 百度 中 查询 PHP 7 的 新 功能 和 优势 。 


第 2 章 配置 PHP7 服务 器 环境 


在 编写 PHP 文件 之 前 ， 读 者 需要 配置 PHP 服务 器 ， 包 括 软 硬 件 环境 的 检查 、 如 何 获得 PHP 
安装 资源 包 等 ， 本 章 将 详细 讲解 目前 常见 的 主流 PHP 服务 器 搭配 方案 : PHP 7+IIS 和 PHP 7+ 
Apache。 另 外 将 讲述 在 Windows 下 如 何 使 用 WampServe 组 合 包 ， 最 后 通过 一 个 实战 演练 ， 检 查 
Web 服务 器 的 构建 是 否 成 功 。 

本 章 学 习 目标 
@ 了解 PHP 服务 器 的 概念 


@ 。 热 愁 安装 PHP 7 前 的 准备 工作 
@ 掌握 PHP7+Apache 服务 器 的 环境 搭建 方法 


2.1 PHP 服务 器 概述 


在 学 习 PHP 服务 器 之 前 , 读者 需要 了 解 HTML 网 页 的 运行 原理 。 网 页 浏览 者 在 客户 端 通过 浏 
览 器 向 服务 器 发 出 页 面 请 求 , 服务 器 接收 到 请 求 后 将 页 面 返回 到 客户 端的 浏览 器 , 这 样 网 页 浏览 者 
即 可 看 到 页 面 显示 效果 。 

PHP 语言 在 Web 开发 中 作为 嵌入 式 语 言 ， 需 要 嵌入 到 HTML 代码 中 执行 。 要 想 运行 PHP 网 
站 ， 需 要 搭建 PHP 服务 器 。PHP 网 站 的 运行 原理 如 图 2-1 所 示 。 





请 求 页 面 


返回 页 面 


客户 端 















































PHP 网 站 的 服务 


数据 库 


图 2-1 PHP 网 站 运行 流程 图 
从 图 2-1 可 以 看 出 ，PHP 程序 运行 的 基本 流程 如 下 。 
@ 网 页 浏览 者 首先 在 浏览 器 的 地 址 栏 中 输入 要 访问 的 主页 地 址 ， 按 回 车 键 触 发 这 个 申请 。 
@ ”浏览 器 将 申请 发 送 到 PHP 网 站 服务 器 。 网 站 服务 器 根据 申请 读 取 数 据 库 中 的 页 面 。 
@ ”通过 Web 服务 器 向 客户 端 发 送 处 理 结果 ， 客 户 端的 浏览 器 显示 最 终 页 面 。 


由 于 在 客户 端 显示 的 只 是 服务 器 端 处 理 过 的 HTML 代码 页 面 ， 所 以 网 页 浏览 者 看 不 
到 PHP 代码 ， 这 样 可 以 提高 代码 的 安全 性 。 同 时 在 客户 端 不 需要 配置 PHP 的 环境 ， 
提 示 主要 安装 浏览 器 即 可 。 
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2.2 安装 PHP 7 前 的 准备 工作 
在 安装 PHP 之 前 ， 要 了 解 安装 所 需要 的 软 硬 件 环境 和 如 何 获取 PHP 安装 资源 包 。 


2.2.1 软 硬 件 环 境 


大 部 分 软件 在 安装 过 程 中 都 需要 软 硬 件 环境 的 支持 ， 当 然 PHP 也 不 例外 。 在 硬件 方面 ， 如 果 
只 是 为 了 学 习 上 的 需求 ，PHP 只 需要 一 台 普 通 的 电脑 即 可 。 在 软件 方面 需要 根据 实际 工作 的 需要 
选择 不 同 的 Web 服务 软件 。 

PHP 具有 器 平台 特性 ， 所 以 PHP 开发 用 什么 样 的 系统 不 太 重要 ， 开 发 出 来 的 程序 都 能 很 轻松 
地 移植 到 其 他 操作 系统 中 。 另 外 ，PHP 开发 平台 支持 目前 主流 的 操作 系统 ， 包 括 Windows 系列 、 
Linux、Unix 和 Mac OSX 等。 下 面 以 Windows 7 平台 为 例 进行 讲解 。 

另外 ， 用 户 还 需要 安装 Web 服务 软件 。 目 前 ，PHP 支持 大 多 数 Web 服务 软件 ， 常 见 的 有 JIS、 
Apache、PWS 和 Netscape 等 。 比 较 流 行 的 是 IIS 和 Apache， 下 面 将 详细 讲述 这 两 种 Web 服务 器 的 
安装 和 配置 方法 。 


2.2.2 ”获取 PHP 7 安装 资源 包 
PHP 安装 资源 包 中 包括 安装 和 配置 PHP 服务 器 的 所 需 文件 和 PHP 扩展 函数 库 。 获 取 PHP 安装 次 
源 包 的 方法 比较 多 ， 很 多 网 站 都 提供 PHP 安装 包 ， 建 议 读 者 从 官方 网 站 下 载 ， 具 体操 作 步 骤 如 下 。 
加 打开 IE 浏览 器 ， 在 地 址 栏 中 输入 下 载 地 址 http:/windows.phpneydownload， 按 回 车 键 确 
认 ， 进 入 PHP 下 载 网 站 ， 如 图 2-2 所 示 。 
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图 2-2 PHP 网 站 下 载 页 面 
贺 进入 下 载 页 面 ， 单 击 【Binaries and sources Releases】〗 下 方 的 下 拉 菜 单 ， 在 弹出 的 下 拉 列 
表 中 选择 适合 的 版 本 ， 这 里 选择 PHP 7 版 本 ， 如 图 2-3 所 示 。 
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图 2-3 选择 需要 的 版 本 


【 在 图 2-3 的 下 拉 列 表 中 VC14 代表 的 是 Visual Studio 2015 Compiler 编译 器 编译 ， 通 常 
于 使 用 在 IIS+PHP 服务 器 下 ， 要 求 用 户 安装 Visual C++ Redistributable for Visual Studio 
不 ET 


显示 所 选 版 本 号 中 PHP 安装 包 的 各 种 格式 , 这 里 选择 Zip 的 压缩 格式 , 单 击 【Zip】 链 接 ， 
如 图 2-4 所 示 。 





























[® htp/Mindows.php.net/downloadsphp-7.0-nts-vC14-x86 Sp-cl 
居 PHP For Windows: Binari.. x 
文件 (月 ” 坊 名 (下 查看 (V) ”收藏 夫 (A) 工具 (T) 帮助 (H) 
/our own 
[ yons VC14 x86 Non Thread Safe (2016-May-25 23:02:14) ~ 
> WiN. [20.93MB] 
; C5369854c23852d361cc50467343c6d1f1e572de 
® Dabug Pack [14.69MB] 
ows 
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vorked 
an be 
‘om the VC14 x86 Thread Safe (2016-May-25 23:02:14) 
® Zp[21Me] 
\ release shal: 634c43fc043787da7923508990607df236a0f29d 
Fess 。 Debug Pack [14.82MB] 
shal: 40a0f14dc7881d76aa05e13b3630216bcd582a0e v 
< > 
http://windows.php.net/downloads/releases/php-7.0.7-nts-Win32-VC14-x86.zip R100% ~ 





图 2-4 选择 需要 版 本 的 格式 
打开 【另存 为 〗 了 对 话 框 ， 选 择 保存 路 径 ， 然 后 保存 文件 即 可 ， 如 图 2-5 所 示 。 
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文件 名 (N): php-7.0.7-nts-Win32-VC14-x86.zip 
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图 2-5 【另存 为 】 对 话 框 


2.3 PHP 7+Apache 服务 器 的 环境 搭建 


Apache 支持 大 部 分 操作 系统 ， 搭 配 PHP 程序 的 应 用 ， 就 可 以 开发 出 功能 强大 的 互动 网 站 。 本 
节 主 要 讲述 PHP 7+Apache 服务 器 的 搭建 方法 。 


2.3.1 Apache 简介 


Apache 是 世界 排名 第 一 的 Web 服务 器 软件 。 它 可 以 运行 在 几乎 所 有 广泛 使 用 的 计算 机 平台 上 ， 
由 于 其 跨 平 台 特 性 和 安全 性 被 广泛 使 用 ， 是 最 流行 的 Web 服务 器 端 软件 之 一 。 


和 一 


般 的 Web 服务 器 相 比 ，Apache 的 主要 特点 如 下 。 


跨 平台 应 用 : 几乎 可 以 在 所 有 的 计算 机 平台 上 运行 。 

开发 源 代 码 : Apache 服务 程序 由 全 世界 众多 开发 者 共同 维护 ， 并 且 任何 人 都 可 以 自由 使 
用 ， 充 分 体现 了 开源 软件 的 特性 。 

支持 HTTP/1.1 协议 : Apache 是 最 先 使 用 HTTP/1.1 协议 的 Web 服务 器 之 一 ， 它 完全 兼容 
HTTP/1.1 协议 并 与 HTTP/1.0 协议 向 后 兼容 。Apache 已 为 新 协议 所 提供 的 全 部 内 容 做 好 
了 必要 的 准备 。 

支持 通用 网 关 接口 (CGI): Apache 遵守 CGI/1.1 标准 并 且 提供 了 扩充 的 特征 ， 如 定制 环 
境 变量 和 很 难 在 其 他 Web 服务 器 中 找到 的 调试 支持 功能 。 

支持 常见 的 网 页 编程 语言 : 可 支持 的 网 页 编程 语言 包括 Perl、PHP、Python 和 Java 等 ， 
支持 各 种 常用 的 Web 编程 语言 ， 使 Apache 具有 更 广泛 的 应 用 领域 。 

模块 化 设计 : 通过 标准 的 模块 实现 专 有 的 功能 ， 提 高 了 项 目 完成 效率 。 

运行 非常 稳定 ， 同 时 具备 效率 高 、 成 本 低 的 特点 ， 而 且 具 有 良好 的 安全 性 。 
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2.3.2 ”关闭 原 有 的 网 站 服务 器 


在 安装 Apache 网 站 服务 器 之 前 ， 如 果 所 使 用 的 操作 系统 已 经 安装 了 网 站 服务 器 , 如 IIS 网 站 
服务 器 等 ， 用 户 必须 先 停止 这 些 服务 器 ， 才 能 正确 安装 Apache 网 站 服务 器 。 

以 Windows 7 的 操作 系统 为 例 ， 请 在 桌面 上 右 击 【 我 的 电脑 】 图 标 ， 在 弹出 的 快捷 菜单 中 选 
择 【 管 理 】 菜 单 命令 ， 打 开 【 计 算 机 管理 】 窗 口 ， 在 左 侧 的 列表 中 展开 【服务 和 应 用 程序 】 选 项 ， 
然后 选择 【Internet 信息 服务 (IIS) 管理 器 】 选 项 ， 在 右 侧 的 列表 中 单 击 【停止 】 按 钮 即 可 停止 IS 
服务 器 ， 如 图 2-6 所 示 。 
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图 2-6 【计算 机 管理 】 窗 口 
如 此 一 来 ， 原 来 的 服务 器 软件 立即 失效 不 再 工作 ， 也 不 会 与 Apache 网 站 服务 器 产生 冲突 。 当 
然 ， 如 果 用 户 的 系统 原来 就 没有 安装 IIS 等 服务 器 软件 ， 即 可 略 过 这 一 节 的 步骤 直接 往 下 执行 。 
2.3.3 安装 Apache 


Apache 是 免费 软件 ， 用 户 可 以 从 官方 网 站 直接 下 载 。Apache 的 官方 网 站 为 : 
http://www.apache.org。 
下 面 以 下 载 好 的 Apache 2.4 为 例 ， 讲 解 如 何 安装 Apache， 上 有 具体 操作 步 骤 如 下 。 


在 浏览 器 的 地 址 栏 中 输入 http://windows.php.net/download/， 按 回 车 键 ， 进 入 Apache 2.4 
下 载 页 面 ， 根 据 系统 的 位 数 选 择 32 位 或 者 64 位 ， 这 里 选择 32 位 的 Apache 2.4， 如 图 2-7 所 示 。 
贺 下 载 完成 后 ， 解 压 到 D 益 中 ， 这 里 解压 路 径 为 : D:\webvapache24\， 如 图 2-8 所 示 。 





PHP+MySQL 动态 网 站 开发 从 入 门 到 精通 (视频 教学 版 ) 














@S hp/wwapacheloungecom/dowrlo @ P= g| 一 padevaabmaresa- x| | me 
文件 ” 编 强 (E) 可 看 (V) ”收音 闪失) 工具 (帮助 (HI 
Be sure that you have installed the latest C++ Redistributable Visual Studio 2015 : vc redis、 


Apache 2.4 binaries VC14 


Info & Changelog 

















Apache 2.4.20 Win64 


© httpd-2.4.20-win64-Vc14.zip 4 May '16 14.613K 
PGE Signature (Public PGP key)，SHR1-SHR512 Checksums 


Apache 2.4.20 Win32 








© httpd-2.4.20 vin3 和 714-zip 4 May "16 13.678K 


EGP Signature (Public PGP key)，SHR1-SHR512 checksums 


This website uses cookies to ensure you get the 
best experience 
hapy /om spacholounge. com/downioad/VC1A/binarioc/ tipd- 27.4.10- wna VC1A.- 














图 2-7 Apache 2.4 下 载 页 面 
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图 2-8 解压 Apache 压缩 包 


2.3.4 将 PHP 与 Apache 建立 关联 


Apache 解压 完成 后 ， 还 不 能 运行 PHP 网 页 ， 需 要 将 PHP 与 Apache 建立 关联 。 

Apache 的 配置 文件 名 称 为 httpd.conf， 它 是 纯 文本 文件 ， 用 记事 本 即 可 打开 编辑 。 此 文件 存放 
在 Apache 安装 目录 的 apache24/conf/ 下 ， 打 开 Apache 的 配置 文件 ， 首 先 设置 网 站 的 主 目录 。 这 里 
将 案例 的 源 文 件 放 在 D 盘 的 phpbook 文件 夹 下 ， 所 以 设置 主 目录 为 d:/phpbook/。 在 http.conf 文件 
中 找到 DocumentRoot 参数 ， 将 其 值 修改 为 d:/phpbook/， 如 图 2-9 所 示 。 
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文件 ( 虽 。“ 编 往 (6 格 z(D) 于 看 (V) 帮助 (H) 


# e-mailed. This address appears on some server-generated pages, such 
# as error documents. e.g. admirfyour-domain. com 
并 





ServerAdmin dfasdffad®152. com 


# 

# ServerName gives the name and port that the server uses to identify 
itself. 

# This can often be determined automatically, but we recommend you specify 
# it explicitly to prevent problems during startup. 

荐 


# If your host doesn' +t have a registered DNS name，enter its IP address 
here. 
并 


#ServerName localhsot:80 
# DocumentRoot: The directory out of which you will serve your 
# documents. By default, all requests are taken from this directory, but 


# symbolic links and aliases may be used to point to other locations. 


# 
DocumentRoot “EH 








图 2-9 设置 网 站 的 主 目录 
下 面 指定 php.ini 文件 的 存放 位 置 。 由 于 PHP 安装 在 d\PHP 7， 所 以 php.ini 位 置 为 d:\PHP 


7\php.ini。 在 httpd.conf 配置 文件 中 的 任意 位 置 加 入 语句 PHPIniDir "di\PHP 7php.ini"， 如 图 2-10 所 


不 。 


文件 (F) 编 句 (E) 悟 式 (O) 可 看 (V) 帮助 (H) 
# virtual host being defined. 
检 





检 

# ServerAdmin: Your address, where problems with the server should be 
# e-mailed. This address appears on some server-generated pages, such 
# as error documents. e.g. admin@your-domain.com 


枯 
ServerAdmin dfasdffad®152. com 


# ServerName gives the name and port that the server uses to identify 
itself. 

# This can often be determined automatically, but we recommend you 
specify 

# it explicitly to prevent problems during startup. 

检 


# If your host doesn' t have a registered DNS name, enter its IP address 
re. 


检 
#ServerName localhsot 
HPIniDir 





图 2-10 指定 php.ini 文件 的 存放 位 置 
最 后 向 Apache 中 加 入 PHP 模块 。 在 httpd.conf 配置 文件 中 的 任意 位 置 加 入 3 行 语句 : 


LoadModule PHP 7 module "d:/PHP 7/PHP 7apache2_4.dl11" 
AddType application/x-httpd-php .php 
AddType application/x-httpd-php .html 


输入 效果 如 图 2-11 所 示 。 完 成 上 述 操作 后 ， 保 存 httpd.conf 文件 。 
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文件 (月 ”编辑 (E) 格式 (O) 坦 看 (V) 帮助 (H) 





# 

# ServerAdmin: Your address, where problems with the server should be 
# e-mailed. This address appears on some server-generated pages, such 
# as error documents. e.g. admin@your-domain. com 


# 
ServerAdmin dfasdffad@152. com 


# ServerName gives the name and port that the server uses to identify 国 
itself. 

# This can often be determined automatically, but we recommend you 
specify 

# it explicitly to prevent problems during startup. 

# 


# If your host doesn’ t have a registered DNS name, enter its IP address 
here. 
## 


#ServerName localhsot:80 
PHPIniDir “ p7\p 





图 2-11 向 Apache 中 加 入 PHP 模板 


最 后 就 是 把 apache 加 入 windows 服务 ， 并 启动 apache。 单 击 【开始 】 菜 单 ， 在 弹出 的 菜单 中 
选择 【运行 】 命 令 ， 在 【打开 】 文本 框 中 输入 cmd， 单 击 【 和 确定】 按钮， 进入 DOS 命令 窗口 ， 首 
先进 入 Apache2.4 的 目录 下 ， 命 令 如 下 : 


cd D:\web\apache24\ 


启动 apache 服务 ， 命 令 如 下 : 


httpd -k install 
httpd -k start 


2.4 ”PHP 环境 的 集成 软件 


对 于 刚 开始 学 习 PHP 的 程序 员 ， 往 往 为 了 配置 环境 而 不 知 所 措 。 为 此 ， 这 里 介绍 一 款 对 
新 手 非常 实用 的 PHP 集成 开发 环境 。 

WampServe 是 指 在 Windows 服务 器 上 使 用 Apache、MySQL、PHP 和 phpmyadmin 的 集成 
安装 环境 ， 目 前 WampServe 3 已 经 支持 PHP 7 版 本 。 由 于 WampServe 安装 简单 、 速 度 较 快 、 
运行 稳定 ， 所 以 受到 广大 初学 者 的 青睐 。 


0 在 安装 WampServer 组 合 包 之 前 ， 需 要 确保 系统 中 没有 安装 Apache、PHP 和 MySQL。 
闪 丰 否则 ， 需 要 先 讲 这 些 软 件 印 载 ， 然 后 才能 安装 WampServer 组 合 包 。 
示 


安装 WampServer 组 合 包 具体 操作 步骤 如 下 : 


到 wampserver 的 官方 网 站 http://www.wampserver.com/en/ 下 载 wampserver 的 最 新 安装 包 
WampServer 3 -x32.exe 文件 。 
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直接 双击 安装 文件 ， 打 开 选 择 安装 语言 对 话 框 ， 这 里 采用 默认 的 设置 ， 单 击 OK 按钮 ， 
如 图 2-12 所 示 。 
在 打开 的 窗口 中 选择 【Iaccept the agreement】 单 选 按钮 ， 如 图 2-13 所 示 。 





Uicense Agreement 
Please read the folowng mportant information before continung. 





License Agreement. You must accept the terms of this 





:Roman 
fupgrade to 2.5 : Lederc 
jade 2.5 to 3.0.0 + Otomatic (wampserver Botomatic ne 


(GNU LESSER GENERAL PUBLIC LICENSE 
Verson 3, 29 June 2007 


Laccept the agreement 
D1do not accept the agreement 








图 2-12 选择 安装 语言 对 话 框 图 2-13 ”接受 许可 证 协议 
单 击 【next] 按钮 打开 检查 安装 信息 窗口 ， 提 示 用 户 需 要 在 系统 中 安装 Microsoft Visual 


Wy 否则 安装 会 出 错 ， 如 图 2-14 所 示 。 
单 击 【next]】 按钮 ， 在 打开 的 窗口 中 设置 安装 路 径 ， 这 里 采用 默认 设置 ， 如 图 2-15 所 示 。 


Information Select Destination Location 
Please read the folowng mportant nformation before contnung. Where should Wampserver32 be instaled? 


re re er ne eee ,Seho wanetal Wanpservers2 nto the folowng foder, 








go dein 030c70=30579 = 
一 vc13 Packages] (Visual C** 20130 | To continue, cick Next. If you would lke to selecta different folder, dick Browse, 
|The two flles VSU4Wcredist_x86.exe and VSU4wcredist_x64 exe to be 

|download are on the same page: https /www microsoft comyen- Browse... 


luegounioog getoss aspxpdes07B 
一 vc14 Packages (Visual C++ 2015) 
|The two fles veredist_x86 exe and veredist_x64.exe to be download 
lare on the same page 
ek 

Ifyou have a 64-bit Windows, you must install 32 and 4bt 
lversions, even ifyou do not use Wampserver 64 
nme NT se Wempserver 

orum 


He 


Atleast 1.873.4MB of free disk space is required. 
er Inetal by I 


Cm Lees> ] (cme | 


jampsefyer Install by Inro Setup 一 














图 2-14 检查 安装 信息 图 2-15 设置 安装 路 径 


单 击 【next】 按钮 ， 在 打开 的 窗口 中 确认 安装 的 参数 后 ， 单 击 【Install】 按 钮 ， 如 图 2-16 
所 示 。 
程序 开始 自动 安装 ， 并 显示 安装 的 进度 ， 如 图 2-17 所 示 。 
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， FE 
Ready to Install Installing 
Setp is non ready to begn netalng Wameserver32 on yo corputer, Peace wat whie seup natale Wonpserver32 on your computer. 
Cidk nestal to contnoe with the natalaton or Gk Backif you want to review or Eracin fles.. 
change any settings. CWwamplbnynysq mysq5.7.11Ww nysdiserver .Ww 
人 刘 ee 
Cwamp 
Start Menu folder: 
Wampsenyer 2 


[me Casa ] [one ] 
图 2-16 确认 安装 窗口 图 2-17 程序 开始 安装 


加 程序 安装 过 程 完毕 后 ， 进 入 安装 完成 窗口 ， 单 击 【Finish】〗 按 钮 ， 完 成 WampServer 的 安 
装 操作 ， 如 图 2-18 所 示 。 

加 单 击 桌面 右 侧 WampServer 服务 按钮 国 ， 在 弹出 的 列表 中 选择 【Localhost] 选项 ， 如 图 
2-19 所 示 。 











ed by Otomatic 











[em] Complcting the Wampscrver32 过 
WW Setup Wizard S 
pda Seap hac reed raing waneaerve 12 en yar orp m 
RCR 汉 
Alter Way 电 
Verslon 3.0.0 by enet She 
Otomatle 六 
‘Wampserver 3.0.4 总 
32 bit x86 人 
Apache 2.4.18 天 Start All Services 
PHP 5.6.19/7.0.4 六 
MySQL 5.7.11 :op al senices 
Restart All Services 
< E23 人 一 可 | -一 一 
图 2-18 完成 安装 图 2-19 WampServer 服务 列表 


罗 自动 打开 浏览 器 ， 显示 PHP 配置 环境 的 相关 信息 ， 如 图 2-20 所 示 。 
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图 2-20 ”PHP 配置 环境 的 相关 信息 
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2.5 ”实战 演练 一 一 我 的 第 一 个 PHP 程序 


前 面 讲 述 了 3 种 服务 器 环境 的 搭建 方法 ， 读 者 可 以 根据 自己 的 需求 进行 选择 。 
下 面 通 过 一 个 实例 讲解 如 何 编写 PHP 程序 并 运行 查看 效果 。 以 IIS 服务 器 环境 为 例 进行 讲解 。 
读者 可 以 使 用 任意 的 文本 编辑 软件 ， 如 记事 本 ,新建 名 称 为 hello world 的 文件 ， 并 输入 以 下 代码 。 


<HTML> 

<HEAD> 

</HEAD> 

<BODY> 

<h2>PHP Hello World - 来 自 PHP 的 问候 。</h2> 

<?php 
echo "Hello, World."; 
echo "你 好 世界 。"; 

?> 

</BODY> 

</HTML> 


将 文件 保存 在 主 目录 或 虚拟 目录 下 ,保存 格式 为 .php。 在 浏览 器 的 地 址 栏 中 输入 
http://localhost/helloworld.php， 并 按 回 车 键 确 认 ， 运 行 结果 如 图 2-21 所 示 。 
< 回 @ rapylocahos P » BOX| Blocahost 


文件 (F) 。 骗 句 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


PHP Hello World - 来 自 PHP 的 
问候 。 














Hello，World. 你 好 世界 。 





图 2-21 运行 结果 
【案例 分 析 】: 


(1) 其 中 “PHP Hello World - 来 自 PHP 的 问候 。” 是 HTML 中 的 “<h2>PHP Hello World 
- 来 自 PHP 的 问候 。</h2>” 所 生成 的 。 

(2) “Hello, World. 你 好 世界 。” 则 是 由 “<?php echo "Hello，World."; echo "你 好 世 
界 。"; ?>” 生 成 的 。 

(3) 在 HTML 中 嵌入 PHP 代码 的 方法 即 是 在 <?php ?> 标识 符 中 间 填 入 PHP 语句 ， 语 句 要 以 
“; ”号 结束 。 

(4) <?php?> 标 识 符 的 作用 ， 就 是 告诉 Web 服务 器 ，PHP 代码 从 什么 地 方 开始 ， 到 什么 地 方 
结束 。<?php ?> 标识 符 内 的 所 有 文本 都 要 按照 PHP 语言 进行 解释 ， 以 区 别 于 HTML 代码 。 
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2.6 ”高 手 私房 菜 


技巧 1: 如 何 设 置 网 站 的 主 目录 ? 

在 Windows 7 操作 系统 中 ， 设 置 网 站 的 主 目录 的 方法 如 下 。 

利用 本 章 的 方法 打开 【计算 机 管理 】 窗 口 ， 选 择 【Default Web Site】 选 项 ， 如 图 2-22 所 示 。 

在 右 侧 的 窗 格 中 单 击 【基本 设置 】 链 接 ， 打 开 【 编 辑 网 站 】 对 话 框 ， 单 击 【物理 路 径 】 下 的 加 
按钮 ， 即 可 在 打开 的 对 话 框 中 重新 设置 网 站 的 主 目录 ， 如 图 2-23 所 示 。 









































i EC 
物理 路 径 (P); 
%SystemDrive%\inetpub\wwwroot 四 
传 间 身 份 验 下 
[mw |] 
图 2-22 【计算 机 管理 】 窗 口 图 2-23 【编辑 网 站 】 对 话 框 


技巧 2: 启动 Apache 2.4 出 错 ， 提 示 缺 少 msvcr110.dll 怎么 办 ? 


安装 Apache 2.4 之 前 ， 请 用 户 务必 安装 Visual C++ 2015， 同 时 启动 以 下 三 个 服务 : windows 
modules installer、windows update 和 window defender service， 和 否则 启动 Apache 2.4 一 定 会 失败 。 


2.7 经典 习 题 


(1) 配置 PHP 7+Apache 服务 器 环境 。 
(2) 安装 WampServe 配置 PHP 7 服务 器 集成 环境 。 
(3) 测试 PHP 服务 器 是 否 配置 成 功 。 


第 3 章 PHP7 的 基本 语法 


上 一 章 讲 述 了 PHP 7 的 环境 搭建 方法 ,本 章 将 开始 学 习 PHP 的 基本 语法 , 主要 包括 PHP 的 标 
识 符 、 编 码 规范 、 常 量 、 变 量 、 数 据 类 型 、 运 算 符 和 表达 式 等 。 通 过 本 章 的 学 习 ， 读 者 可 以 掌握 
PHP 的 基本 语法 知识 和 技能 。 


本 章 学 习 目 标 


了 解 PHP 标识 符 

熟悉 PHP 的 编码 规范 
掌握 常量 的 使 用 方法 
掌握 变量 的 使 用 方法 
掌握 数据 类 型 

掌握 运算 符 的 使 用 方法 
掌握 表达 式 的 使 用 方法 
掌握 创建 多 维 数组 的 方法 


3.1 PHP 标识 符 


默认 情况 下 ，PHP 是 以 <?php ?> 标识 符 为 开始 和 结束 标记 的 。 但 是 ，PHP 代码 有 不 同 的 表示 
风格 。 最 为 常用 的 风格 就 是 这 种 默认 方法 ， 也 有 人 把 这 种 默认 风格 称 为 PHP 的 XML 风格 。 下 面 
将 学 习 其 他 类 型 的 标识 风格 。 
3.1.1 短 风格 

有 时 候 ， 读 者 会 看 到 一 些 代码 中 出 现 用 <? ?> 标识 符 表示 PHP 代码 的 情况 。 这 就 是 所 谓 的 “ 短 
风格 ”short style) 表示 法 。 例 如 : 

<? echo "这 是 PHP 短 风格 的 表示 方式 。"?> 

这 种 表示 方法 在 正常 情况 下 并 不 推荐 ， 并 且 在 php.ini 文件 中 short_open_tags 的 默认 设置 是 关 
闭 的 。 另外， 以 后 提 到 的 一 些 功 能 设置 会 与 这 种 表示 方法 相 冲 突 ， 比 如 与 XML 的 默认 标识 符 相 冲 


3.1.2 script 风格 


有 的 编辑 器 由 于 跟 以 前 程序 的 定义 表示 要 区 分 开 ， 对 PHP 代码 完全 采用 另外 一 种 表示 方式 ， 
即 <script></scrip 人 的 表示 方式 。 例 如 : 


<script language="php"> 
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echo "这 是 PHP 的 script 表示 方式 。"; 
</script> 


这 十 分 类 似 于 HTML 页 面 中 JavaScript 的 表示 方式 。 
3.1.3 ASP 风格 
由 于 ASP 的 影响 , 为 了 照顾 ASP 使 用 者 对 PHP 的 使 用 , PHP 提供 了 ASP 的 表示 风格 , 例如 : 


< 
echo "这 是 PHP 的 ASP 的 表示 方式 。"; 
和 > 


这 种 表示 是 在 特殊 情况 下 使 用 的 ， 并 不 推荐 正常 使 用 。 


3.2 编码 规范 


由 于 现在 的 Web 开发 往往 是 多 人 一 起 合作 完成 的 ， 所 以 使 用 相同 的 编码 规范 显得 非常 重要 ， 
特别 是 新 的 开发 人 员 参 与 时 , 通常 需要 知道 前 面 开 发 代码 中 变量 或 函数 的 作用 等 , 这 就 需要 统一 的 


3.2.1 什么 是 编码 规范 


编码 规范 是 一 套 某 种 编程 语言 的 导 引 手册 ， 这 种 导 引 手册 规定 了 一 系列 这 种 语言 的 默认 编程 
风格 ， 以 用 来 增强 这 种 语言 的 可 读 性 、 规 范 性 和 可 维护 性 。 一 个 语言 的 编码 规范 主要 包括 : 此 语言 
下 的 文件 组 织 、 缩 进 、 注 释 、 声 明 、 空 格 处 理 、 命 名 规则 等 。 

遵守 编码 规范 有 以 下 好 处 。 

@ ”编码 规范 是 团队 开发 中 对 每 个 成 员 的 基本 要 求 。 编 码 规范 的 好 坏 是 一 个 程序 员 成 熟 程度 

的 表现 。 

@ ”提高 程序 的 可 读 性 ， 有 利于 开发 人 员 互 相交 流 。 

@ ”良好 一 致 的 编程 风格 ， 在 团队 开发 中 可 以 达到 事半功倍 的 效果 。 

@ 有 助 于 程序 的 维护 ， 降 低 软 件 成 本 。 
3.2.2 PHP 中 的 编码 规范 

PHP 作为 一 种 高 级 语言 ， 十 分 强调 编码 规范 。 以 下 是 此 规范 在 3 个 方面 的 体现 。 

1. 表述 
在 PHP 的 正常 表述 中 ， 每 一 句 PHP 语句 都 是 以 “; ”结尾 ， 这 个 规范 就 告诉 PHP 要 执行 此 
语句 ， 例 如 : 

<?php 


echo "php 以 分 号 表示 语句 的 结束 和 执行 。"; 


> 
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2. 指令 分 隔 符 
在 PHP 代码 中 ， 每 个 语句 后 需要 用 分 号 结束 命令 。 一 段 PHP 代码 中 的 结束 标记 隐 含 表示 了 一 
个 分 号 ， 所 以 在 PHP 代码 段 中 的 最 有 一 行 可 以 不 用 分 号 结束 。 例 如 : 
<?php 
echo "这 是 第 一 个 语句 "; // 每 个 语句 都 加 入 分 号 
echo "这 是 第 二 个 语句 "; 
echo "这 是 最 后 一 个 语句 "?> ”// 结束 标记 “?>” 隐 含 了 分 号 ， 这 里 可 以 省 略 分 号 
3. 空白 符 
PHP 对 空格 、 回 车 造成 的 新 行 、Tab 等 留 下 的 空白 的 处 理 也 遵循 编码 规范 。PHP 对 它们 都 进 
行 了 忽略 。 这 跟 浏览 器 对 HTML 语言 中 的 空白 的 处 理 是 一 样 的 。 
合理 利用 空白 符 可 以 增强 代码 的 可 读 性 和 清晰 性 。 
(1) 下 列 情况 应 该 总 是 使 用 两 个 空白 行 : 
@ 两 个 类 的 声明 之 间 。 
@ 一 个 源 文件 的 两 个 代码 片段 之 间 。 
(2) 下 列 情况 应 该 总 是 使 用 一 个 空白 行 : 
@ 两 个 函数 声明 之 前 。 
@ 函数 内 的 局 部 变量 和 函数 的 第 一 个 语句 之 间 。 
@ 块 注释 或 单行 注释 之 前 。 
@ 一 个 函数 内 的 两 个 逻辑 代码 段 之 间 。 
(3) 合理 利用 空格 可 以 提高 代码 的 缩 进 ， 提 高 可 读 性 。 
@ 空格 通常 使 用 于 关键 字 与 括号 之 间 ， 但 是 ， 函 数 名 称 与 左 括号 之 间 不 使 用 空格 分 开 。 
@ 函数 参数 列表 中 的 逗号 后 面 通常 会 插入 空格 。 
@ for 语句 的 表达 式 应 该 用 逗号 分 开 ， 后 面 添加 空格 。 
4. 注释 
为 了 增强 可 读 性 ， 在 很 多 情况 下 ， 程 序 员 都 需要 在 程序 语句 的 后 面 添加 文字 说 明 。 而 PHP 要 
把 它们 与 程序 语句 区 分 开 ， 就 需要 让 这 些 文字 注释 符合 编码 规范 。 
这 些 注 释 的 风格 有 几 种 ， 分 别 是 C 语言 风格 、C++ 风 格 和 SHELL 风格 。 
C 语言 风格 如 下 : 
/* 这 是 C 语言 风格 的 注释 内 容 */ 
这 种 方法 还 可 以 多 行使 用 : 
/* 这 是 
C 语言 风格 
的 注释 内 容 
wy 
C++ 风格 如 下 : 
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// 这 是 c++ 风格 的 注释 内 容 行 一 

// 这 是 c++ 风格 的 注释 内 容 行 二 

这 种 方法 只 能 一 句 注释 占用 一 行 。 使 用 时 可 单独 一 行 , 也 可 以 使 用 在 PHP 语句 之 后 的 同一 行 。 
SHELL 风格 如 下 : 

# 这 是 SHELL 风格 的 注释 内 容 


这 种 方法 只 能 一 名 注释 占用 一 行 。 使 用 时 可 单独 一 行 ， 也 可 以 使 用 在 PHP 语句 之 后 的 
同一 行 。 
5. 与 HTML 语言 混合 搭配 


凡是 在 一 对 PHP 开始 和 结束 标记 之 外 的 内 容 都 会 被 PHP 解析 器 忽略 ， 这 使 得 PHP 文件 可 以 
具备 混合 内 容 。 可 以 使 PHP 嵌入 到 HTML 文档 中 去 。 例 如 : 


<HTML> 
<HEAD> 
<TITLE>PHP 与 HTML 混合 </TITLE> 
</HEAD> 
<BODY> 
<?php 
echo "嵌入 的 PHP 代码 "; 














2 
</BODY> 
<HTML> 


3.3 常 量 

在 PHP 中 ， 常 量 是 一 旦 声明 就 无 法 改变 的 值 。 本 节 来 讲述 如 何 声明 和 使 用 常量 。 
3.3.1 声明 和 使 用 常量 

PHP 通过 define() 命 令 来 声明 常量 ， 格 式 如 下 : 

define ("常量 名 "， 常 量 值 ); 

常量 名 是 一 个 字符 串 ， 通 常 在 PHP 的 编码 规范 的 指导 下 使 用 大 写 英文 字母 表示 ， 比 如 
CLASS_ NAME 、MYAGE 等 。 

常量 值 可 以 是 很 多 种 PHP 的 数据 类 型 ， 可 以 是 数组 ， 可 以 是 对 象 ， 当 然 也 可 以 是 字符 
和 数字 。 

常量 就 像 变量 一 样 存储 数值 ， 但 是 与 变量 不 同 的 是 ， 常 量 的 值 只 能 设 定 一 次 ， 并 且 无 论 在 代 
码 的 任何 位 置 ， 它 都 不 能 被 改动 。 常 量 声明 后 具有 全 局 性 ， 在 函数 内 外 都 可 以 访问 。 

【 例 3.1】 (实例 文件 : ch03\3.1.php) 

<?php 

define ("HUANY", "欢迎 学 习 PHP 基本 语法 知识 ") ; // 定义 常量 HUANY 


echo HUANY; // 输出 常量 





PHP 7 的 基本 语法 第 3 章 





2 


本 程序 运行 结果 如 图 3-1 所 示 。 











碟 httpi//localhost PD- CX 
文件 (月 ” 编 强 (E) 得 看 (V) ”收藏 夫 (A) ”工具 (D) ”帮助 (H) 














欢迎 学 习 PHP 基 本 语法 知识 








图 3-1 运行 结果 

【案例 分 析 】: 

@ 用 define 函数 声明 一 个 常量 。 常 量 的 全 局 性 体现 在 可 在 函数 内 外 进行 访问 。 

@ 常量 只 能 存储 布尔 值 、 整 型 、 浮 点 型 和 字符 串 数 据 。 
3.3.2 内置 常量 

PHP 的 内 置 常量 是 指 PHP 在 系统 建立 之 初 就 定义 好 的 一 些 量 。PHP 中 预定 义 了 很 多 系统 内 置 
常量 ， 这 些 常量 可 以 被 随时 调用 。 下 面 列 出 了 一 些 常 见 的 内 置 常 量 。 

1._FILE 

这 个 默认 常量 是 文件 的 完整 路 径 和 文件 名 。 若 引用 文件 (include 或 require) 则 在 引用 文件 内 
的 该 常量 为 引用 文件 名 ， 而 不 是 引用 它 的 文件 名 。 

2._LINE_ 

这 个 默认 常量 是 PHP 程序 行 数 。 若 引用 文件 (include 或 require) 则 在 引用 文件 内 的 该 常量 
为 引用 文件 的 行 ， 而 不 是 引用 它 的 文件 行 。 


3. PHP_VERSION 

这 个 内 置 常量 是 PHP 程序 的 版 本 ， 如 3.0.8-dev。 

4. PHP_OS 

这 个 内 置 常量 是 指 执行 PHP 解析 器 的 操作 系统 名 称 ， 如 Linux。 
5. TRUE 

这 个 常量 就 是 真 值 (true) 。 

6. FALSE 

这 个 常量 就 是 伪 值 (false) 。 

7.E_ERROR 

这 个 常量 指 到 最 近 的 错误 处 。 
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8. E_WARNING 

这 个 常量 指 到 最 近 的 警告 处 。 

9. E_PARSE 

本 常量 指 到 解析 语法 有 潜在 问题 处 。 

10. E_NOTICE 

这 个 常量 为 发 生 不 寻常 但 不 一 定 是 错误 处 ， 例 如 存 取 一 个 不 存在 的 变量 。 

11. _DIR_ 

这 个 常量 为 文件 所 在 的 目录 。 该 常量 在 PHP 5.3.0 版 本 中 新 增 。 

12. _ FUNCTION _ 

这 个 常量 为 函数 的 名 称 。 从 PHP 5 开始 ， 此 常量 返回 该 函数 被 定义 时 的 名 字 ， 并 且 





分 大 小 写 。 
13. _CLASS _ 


这 个 常量 为 类 的 名 称 。 从 PHP 5 开始 ， 此 常量 返回 该 类 被 定义 时 的 名 字 ， 并 且 区 分 大 小 写 。 
下 面 举例 说 明 系 统 常量 的 使 用 方法 。 
【 例 3.2】 实例 文件 : ch033.2.php) 


<?php 

echo(_FILE ); // 输出 文件 的 路 径 和 文件 名 
echo “<br />™; // 输出 换行 
echo(_LINE ); // 输出 语句 所 在 的 行 数 


acho “<br />"y 
echo (PHP_VERSION) ; // 输出 PHP 的 版 本 
echo “<br />™; 
echo (PHP_O0S); // 输出 操作 系统 名 称 


2 


本 程序 运行 结果 如 图 3-2 所 示 。 
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C:\ch03\3. 2. php 











图 3-2 程序 运行 结果 
【案例 分 析 】: 
(1) echo “<br />“ 语 句 表 示 为 输出 换行 。 


Xl 
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(2) echo(_FILE ) 语 句 输出 文件 的 文件 名 ， 包 括 详细 的 文件 路 径 。echo(_LINE ) 语 句 输出 该 
语句 所 在 的 行 数 。echo(PHP_ VERSION) 语 句 输出 PHP 程序 的 版 本 。echo(PHP_OS) 语 句 输出 执行 
PHP 解析 器 的 操作 系统 名 称 。 


3.4 变 量 


变量 像 一 个 贴 有 名 字 标 签 的 空 盒子 。 不 同 的 变量 类 型 对 应 不 同 种 类 的 数据 ， 就 像 不 同 种 类 的 
东西 要 放 入 不 同 种 类 的 盒子 。 


3.4.1 PHP 中 的 变量 声明 


PHP 中 的 变量 不 同 于 C 或 Java 语言 ， 因 为 它 是 弱 类 型 的 。 在 C 或 Java 中 ， 需 要 对 每 一 个 变 
量 声明 类 型 ， 但 是 在 PHP 中 不 需要 这 样 做 。 

PHP 中 的 变量 一 般 以 “$” 作 为 前 级 ， 然 后 以 字母 a~z 的 大 小 写 或 者 “_ ”下划线 开头 。 这 是 

合法 的 变量 名 可 以 是 : 

$hello 


$Aforml 
$_formhandler (类 似 我 们 见 过 的 $_POST 等 ) 。 


非法 的 变量 名 如 : 

$168 

$!like 

PHP 中 不 需要 显 式 地 声明 变量 ， 但 是 定义 变量 前 进行 声明 并 带 有 注释 ， 这 是 一 个 好 的 程序 员 
应 该 养 成 的 习惯 。PHP 的 赋值 有 两 种 ， 包 括 传 值 和 引用 ， 它 们 的 区 别 如 下 : 


(1) 传 值 赋值 : 使 用 “= 直接 将 赋值 表达 式 的 值 赋 给 另 一 个 变量 。 

(2) 引用 赋值 : 将 赋值 表达 式 内 存 的 空间 的 引用 赋 给 另 一 个 变量 。 需 要 在 “= 左右 的 变量 前 
面 加 上 一 个 “&” 符 号 。 在 使 用 引用 赋值 的 时 候 ， 两 个 变量 将 会 指向 内 存 中 同一 个 存储 空间 ， 所 以 
任意 一 个 变量 的 变化 都 会 引起 另外 一 个 变量 的 变化 。 


【 例 3.3】〔 实 例文 件 ，ch03\3.3.php) 


<?php 

echo "使 用 传 值 方式 赋值 : <br/>"; // 输出 使 用 传 值 方式 赋值 : 

$a = " 风 吹 草 低 见 牛 羊 "; 

Sb Sa // 将 变量 $a 的 值 赋值 给 Sb， 两 个 变量 指向 不 同 内 存 空间 
echo "变量 a 的 值 为 " .$a."<br/>"; // 输出 变量 a 的 值 

echo "变量 b 的 值 为 " .$b."<br/>"; // 输出 变量 b 的 值 

$a = "天 似 窒 庐 ， 笼 盖 四 野 " ; // 改变 变量 a 的 值 ， 变 量 b 的 值 不 受 影响 

echo "变量 a 的 值 为 " .$a."<br/>"; // 输出 变量 a 的 值 


echo "变量 b 的 值 为 " .$b."<p>"; // 输 出 变量 b 的 值 

echo "使 用 引用 方式 赋值 : <br/>"; // 输 出 ”使 用 引用 方式 赋值 : 

$a = "天 苍 苑 ， 野 茫茫 "; 

Sb = &$a; // 将 变量 $a 的 引用 赋 给 $bp， 两 个 变量 指向 同一 块 内 存 空 间 
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echo "变量 a 的 值 为 ".$a."<br/>"; ”// 输出 变量 a 的 值 

echo "变量 b 的 值 为 ".$b."<br/>"; ”// 输出 变量 b 的 值 

$a = " 救 勒 川 阴山 下 "7 

/* 

改变 变量 a 在 内 存 空间 中 存储 的 内 容 ， 变 量 b 也 指向 该 空间 ，b 的 值 也 发 生变 化 
ea 

echo "变量 a 的 值 为 ".$a."<br/>"; // 输出 变量 a 的 值 

echo "变量 b 的 值 为 " .$b. "<p>"; // 输出 变量 b 的 值 


a 


本 程序 运行 结果 如 图 3-3 所 示 。 
































文件 虽 。 蝙 名 (E) 下 看 ) 收藏 夫 (A) 工具 (T 帮助 (H) 
使 用 传 值 方式 赋值 : 人 ~ 
变量 a 的 值 为 风 吹 草 低 见 牛 羊 


t 羊 
变量 a 的 值 为 天 似 宫 户 ， 短 善 四 野 
变量 b 的 值 为 风 吹 草 地 现 牛 羊 








使 用 引用 方式 赋值 : 
变量 a 的 值 为 天 苍 苦 ， 野 苍茫 
b 的 值 为 天 苍苍 ， 野 茸 茫 
变量 a 的 值 为 救 勒 川 ， 阴 山下 
变量 b 的 值 为 救 勒 川 ， 阴 山下 








图 3-3 程序 运行 结果 


3.4.2 ”可 变 变 量 与 变量 的 引用 


一 般 的 变量 表示 很 容易 理解 ， 但 是 有 两 个 变量 表示 概念 比较 容易 混淆 ， 就 是 可 变 变 量 和 变量 
的 引用 。 通 过 以 下 例子 对 它们 进行 说 明 。 
【 例 3.4】 〈 实 例文 件 : ch03\3.4.php) 


<?php 
$value0 = "guest"; // 定义 变量 $value0 并 赋值 
$$value0 = "customer"; // 再 次 给 变量 赋值 
echo $guest."<br />"; // 输出 变量 
S$guest = "feifei"; // 定义 变量 $guest 并 赋值 
echo $guest."\t".$$value0."<br />"; 
S$valuel = "xiaoming"; // 定义 变量 $valuel 
$value2 = &$valuel; // 引用 变量 并 传递 变量 
echo $valuel."\t".$value2."<br />"; // 输出 变量 
$value2 = "1ili"; 
echo $valuel."\t".$value2; 

2 


本 程序 运行 结果 如 图 3-4 所 示 。 
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图 3-4 程序 运行 结果 
【案例 分 析 】: 


(1) 在 代码 的 第 一 部 分 , $value0 被 赋值 guest。$value0 相当 于 guest, 则 $$value0 相当 于 $guest。 
所 以 当 $$value0 被 复制 为 customer 时 ， 打 印 $guest 就 得 到 customer。 反 之 ， 当 $guest 变量 被 赋值 为 
feifei 时 ， 打 印 $$value0 同样 得 到 feifei。 这 就 是 可 变 变量 。 

(2) 在 代码 的 第 二 部 分 里 ，$valuel 被 赋值 xiaoming， 然 后 通过 “&” 引 用 变量 $valuel 并 赋 
值 给 $value2。 而 这 一 步 的 实质 是 ， 给 变量 $valuel 添加 了 一 个 别名 $value2。 所 以 打印 时 ， 大 家 都 得 
出 原始 赋值 xiaoming。 由 于 $value2 是 别名 ， 和 $valuel 指 的 是 同一 个 变量 ， 所 以 当 $value2 被 赋值 
li 后，$valuel 和 S$value2 都 得 到 新 值 lili。 

(3) 可 变 变量 ， 其 实 是 允许 改变 一 个 变量 的 变量 名 。 人 允许 使 用 一 个 变量 的 值 作为 另外 一 个 变 
量 的 名 。 

(4) 变量 引用 ， 相 当 于 给 变量 添加 了 一 个 别名 ， 使 用 “& ”来 引用 变量 。 其 实 两 个 变量 名 指 
的 都 是 同一 个 变量 。 就 像 是 给 同一 个 盒子 贴 了 两 个 名 字 标 签 ， 两 个 名 字 标 签 指 的 都 是 同一 个 盒子 。 


3.4.3 变量 作用 域 (variable scope) 


所 谓 变 量 作用 域 (scope) ， 是 指 特定 变量 在 代码 中 可 以 被 访问 到 的 位 置 。 在 PHP 中 有 6 种 基 
本 的 变量 作用 域 法 则 。 

(1) 内 置 超 全 局 变量 (Built-in superglobal variables) ， 在 代码 中 的 任意 位 置 都 可 以 访问 到 。 

(2) 常数 〈constants) ， 一 旦 声明 ， 它 就 是 全 局 性 的 。 可 以 在 函数 内 外 使 用 。 

(3) 全 局 变量 (global variables)， 在 代码 间 声 明 ， 可 在 代码 间 访 问 ， 但 是 不 能 在 函数 内 访问 。 

(4) 在 函数 中 声明 为 全 局 变量 的 变量 ， 就 是 同名 的 全 局 变量 。 

(5) 在 函数 中 创建 和 声明 为 静态 变量 的 变量 ， 在 函数 外 是 无 法 访问 的 。 但 是 这 个 静态 变量 的 
值 可 以 保留 。 

(6) 在 函数 中 创建 和 声明 的 局 部 变量 ， 在 函数 外 是 无 法 访问 的 ， 并 且 在 本 函数 终止 时 失效 。 


1. 超 全 局 变量 


Superglobal 或 autoglobal 可 以 称 为 “ 超 全 局 变量 ”或 “自动 全 局 变量 ”。 这 种 变量 的 特性 是 ， 
不 管 在 程序 的 任何 地 方 都 可 以 访问 到 , 不 管 是 函数 内 或 是 函数 外 也 都 可 以 访问 到 。 而 这 些 “ 超 全 局 
变量 ”就 是 由 PHP 预先 定义 好 以 方便 使 用 的 。 
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那么 这 些 “ 超 全 局 变量 ”或 “自动 全 局 变量 ”都 有 哪些 呢 ? 


$GLOBALS: 包含 全 局 变量 的 数组 。 

$_GET: 包含 所 有 通过 GET 方法 传递 给 代码 的 变量 的 数组 。 

$_POST: 包含 所 有 通过 POST 方法 传递 给 代码 的 变量 的 数组 。 

$_FILES: 包含 文件 上 传 变量 的 数组 。 

$_COOKIE: 包含 cookie 变量 的 数组 。 

$_SERVER: 包含 服务 器 环境 变量 的 数组 。 

$_ENV: 包含 环境 变量 的 数组 。 

$_REQUEST: 包含 用 户 所 有 输入 内 容 的 数组 ( 包括 $_GET、$_POST 和 $_COOKIE )。 
$_SESSION: 包含 会 话 变量 的 数组 。 


. 全 局 变量 

全 局 变量 其 实 就 是 在 函数 外 声明 的 变量 ， 在 代码 间 都 可 以 访问 ， 但 是 在 函数 内 是 不 能 访问 的 。 
这 是 因为 函数 默认 不 能 访问 在 其 外 部 的 全 局 变量 。 

通过 下 面 的 实例 介绍 全 局 变量 的 使 用 方法 和 技巧 。 

【 例 3.5】〈 实 例文 件 : ch033.5.php) 


D 


<?php 
Sroom = 20; // 定义 全 局 变量 
function showrooms () { 
echo $room; // 函数 内 访问 全 局 变量 
} 
showrooms (); // 访问 全 局 变量 
echo $room. ' 间 房间 。'; 
oA 


本 程序 运行 结果 如 图 3-5 所 示 。 








[¢ EL rE [| 
Xen HED FEW BA TR NM 
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2 0.0011 | 139816|showrooms ( ) .3.4.php;11 
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图 3-5 程序 运行 结果 
出 现 上 述 结果 ， 是 因为 函数 无 法 访问 外 部 全 局 变量 ， 但 是 在 代码 间 可 以 访问 全 局 变量 。 
如 果 想 让 函数 访问 某 个 全 局 变量 ， 可 以 在 函数 中 通过 global 关键 字 来 声明 ， 就 是 要 告诉 函数 ， 
它 要 调用 的 变量 是 一 个 已 经 存在 或 者 即将 创建 的 同名 全 局 变量 ， 而 不 是 默认 的 本 地 变量 。 
通过 下 面 的 实例 介绍 global 关键 字 的 使 用 方法 和 技巧 。 





































































































【 例 3.6】《〈 实 例文 件 ， ch03\3.6.php) 





3-6 ”程序 运行 结果 


另外 ， 读 者 还 可 以 通过 “ 超 全 局 变量 ”中 的 SGLOBALS 数组 进行 访问 。 
下 面 通过 以 下 实例 介绍 SGLOBALS 数组 ， 具 体 步 骤 如 下 。 
【 例 3.7】《〈 实 例文 件 ， ch03\3.7.php) 





20 间 新 房间 - 
20 间 房间 。 


图 3-7 程序 运行 结果 
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结果 与 上 面 的 例子 完全 相同 ， 可 见 这 两 种 方法 可 以 实现 同一 个 效果 。 
3 静态 变量 
静态 变量 只 是 在 函数 内 存在 ， 在 函数 外 无 法 访问 。 但 是 执行 后 ， 其 值 保 留 ， 也 就 是 说 这 一 次 
执行 完毕 后 ， 静 态 变量 的 值 保留 ， 下 一 次 再 执行 此 函数 ， 这 个 值 还 可 以 调用 。 
通过 下 面 的 实例 介绍 静态 变量 的 使 用 方法 和 技巧 。 
【 例 3.8】〔 实 例文 件 ， ch03\3.8.php) 
<?php 
$person = 20; // 输出 操作 系统 名 称 
function showpeople(){ 
static $person = 5; 
SPerson++7 
echo ' 再 增加 一 位 ， 将 会 有 ' .$person.' 位 static 人 员 。<br />'; 
} 
showpeople(); 
echo $person.' 人 员 。<br />'; 


showpeople(); 
ir 


本 程序 运行 结果 如 图 3-8 所 示 。 





| htpy/ocalhost P ~ Box| Gs 
文件 (F) 泊 强 (E) 间 看 (V】 收藏 闪 (A) 工具 (Tm 帮助 (H) 


于 位 ， 将 会 有 6 为 static 人 员 . 
0 人 员 。 











ER 位 ， 将 会 有 7 为 static 人 员 。 








图 3-8 程序 运行 结果 

【案例 分 析 】 

(1) 其 中 函数 外 的 echo 语句 无 法 调用 函数 内 的 static Sperson， 它 调用 的 是 $person = 20。 

(2) showpeople() 函 数 被 执行 两 次 ， 这 个 过 程 中 static $person 的 运算 值得 以 保留 ， 并 且 通 过 
$person++ 进 行 了 累加 。 
3.4.4 变量 的 销毁 

当 用 户 创 建 一 个 变量 时 ， 相 应 的 在 内 存 中 有 一 个 空间 专门 用 于 存储 该 变量 ， 该 空间 引用 计数 
加 1。 当 变 量 与 该 空间 的 联系 被 断 开 时 ， 则 空间 引用 计数 减 1， 直 到 引用 计数 为 0， 则 称 为 垃圾 。 

PHP 有 自动 回收 垃圾 的 机 制 ， 用 户 也 可 以 手动 销毁 变量 ， 通 常 使 用 unset() 函 数 来 实现 。 该 函 
数 的 语法 格式 如 下 : 

void unset (变量 ) 


其 中 变量 类 型 为 局 部 变量 ， 则 变量 被 销毁 ;如 果 变 量 类 型 为 全 局 变量 ， 则 变量 不 会 被 销毁 。 
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【 例 3.9】《〈 实 例文 件 : ch03\3.9.php) 


<?php 
function xiaohui() { // 声 明 函数 
global $b; // 函 数 内 使 用 global 关键 字 声 明 全 局 变量 $b 





unset ($b); // 使 用 unset () 销毁 不 再 使 用 的 变量 Sb 
} 
$b= ' 春 江 花 月 夜 '; // 函 数 外 声明 全 局 变量 
xiaohui (); // 调 用 函数 
echo $b; // 查 看 全 局 变量 是 否 发 生变 化 
2> 
本 程序 运行 结果 如 图 3-9 所 示 。 








@S HE htp//loca B D7 OE@ localhost 


文件 (编辑 (E) ”可 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 
春江 花 月 夜 














图 3-9 程序 运行 结 ， 


3.5 ”数据 的 类 型 


从 PHP 4 开始 ，PHP 中 的 变量 不 需要 事先 声明 ， 赋 值 即 可 声明 。 在 使 用 这 些 数 据 类 型 前 ， 读 
者 需要 了 解 它们 的 含义 和 特性 。 下 面 介绍 整 型 、 浮 点 型 、 布 尔 型 、 字 符 串 型 、 数 组 型 、 对 象 型 和 两 
个 较 特 殊 的 类 型 。 

3.5.1 什么 是 类 型 

不 同 的 数据 类 型 其 实 就 是 所 存储 数据 的 不 同 种 类 。PHP 的 不 同 数据 类 型 主要 包括 : 

整 型 (integer )， 用 来 存储 整数 。 

浮 点 型 (float )， 用 来 存储 实数 。 

字符 串 型 (string )， 用 来 存储 字符 串 。 

布尔 型 (boolean )， 用 来 存储 真 (true ) 或 假 (false )。 
数组 型 (array )， 用 来 存储 一 组 数据 。 

@ 对象 型 (object)， 用 来 存储 一 个 类 的 实例 。 

作为 弱 类 型 语言 ，PHP 也 被 称 为 动态 类 型 语言 。 在 强 类 型 语言 ， 例 如 C 语言 中 ， 一 个 变量 只 
能 存储 一 种 类 型 的 数据 ， 并 且 这 个 变量 在 使 用 前 必须 声明 变量 类 型 。 而 在 PHP 中 ， 给 变量 赋 什 么 
类 型 的 值 ， 这 个 变量 就 是 什么 类 型 ， 例 如 以 下 几 个 变量 : 


S$hello = "hello world"; 
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由 于 hello world 是 字符 串 ， 则 变量 Shello 的 数据 类 型 就 是 字符 串 类 型 。 

$hello = 100; 

同样 ， 由 于 100 为 整 型 ，$hello 也 就 是 整 型 。 

Swholeprice = 100.0; 

由 于 100.0 为 浮 点 型 ， 则 $wholeprice 就 是 浮 点 型 。 

由 此 可 见 ， 对 于 变量 而 言 ， 如 果 没 有 定义 变量 的 类 型 ， 则 它 的 类 型 由 所 赋值 的 类 型 决定 。 
3.5.2 ” 整 型 Cinteger) 

整 型 (integer) 是 数据 类 型 中 最 为 基本 的 类 型 。 在 现 有 的 32 位 运算 器 的 情况 下 ， 整 型 的 取 值 
是 从 -2147483648 到 +2147483647。 整 型 可 以 表示 为 十 进 制 、 十 六 进 制 和 八进制 。 

例如 : 


3560 // 十 进 制 整数 
01223 ”// 八 进 制 整数 
0x1223 // 十 六 进 制 整 数 


3.5.3” 浮 点 型 (float 或 double) 


浮 点 型 (floating-point) 就 是 表示 实数 。 在 大 多 数 运 行 平台 下 ， 这 个 数据 类 型 的 大 小 为 8 个 字 
i 。 它 的 近似 取 值 范围 是 2.2E-308~1.8E+308 (科学 计数 法 ) 。 
例如 : 














不 


3.5.4 布尔 型 (boolean) 


布尔 型 (boolean) 只 有 两 个 值 ， 就 是 true 和 false。 布 尔 型 是 十 分 有 用 的 数据 类 型 ， 通 过 它 ， 
程序 实现 了 逻辑 判断 的 功能 。 
其 他 的 数据 类 型 基本 都 有 布尔 属性 : 


@ 整 型 ,为 0 时 ， 其 布尔 属性 为 false， 为 非 零 值 时 ， 其 布尔 属性 为 true。 

@ 浮 点 型 ， 为 0.0 时 ， 其 布尔 属性 为 false， 为 非 零 值 时 ， 其 布尔 属性 为 true。 

@ 字符 串 型 ， 为 空 字符 串 “”， 或 者 零 字 符 串 “0” 时 ， 其 布尔 属性 为 false， 包 含 除 此 以 外 
的 字符 囊 时 其 布尔 属性 为 true。 

@ ”数组 型 ， 若 不 含 任何 元 素 ， 其 布尔 属性 为 false， 只 要 包含 元 素 ， 则 其 布尔 属性 为 true。 

@@。 对象 型 ,资源 型 ， 其 布尔 属性 永远 为 true。 

@ 空 型 ， 其 布尔 属性 永远 为 false。 


3.5.5 字符 串 型 (string ) 


字符 串 型 的 数据 是 表示 在 引号 之 间 的 。 引 号 分 为 双 引 号 〈"") 和 单 引 号 〈''") 。 这 两 种 引号 可 
以 表示 字符 串 。 但 是 这 两 种 表示 方法 也 有 一 定 区 别 。 
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双 引 号 几乎 可 以 包含 所 有 的 字符 ， 但 是 在 其 中 的 变量 显示 变量 的 值 ， 而 不 是 变量 的 变量 名 ， 


而 有 些 特殊 字符 加 上 “\” 符 号 就 可 以 了 ; 单 引号 内 的 字符 是 被 直接 表示 出 来 的 。 


下 面 通 过 一 个 案例 ， 来 讲述 整 型 、 浮 点 型 、 布 尔 型 和 字符 串 型 数据 的 使 用 方法 和 技巧 。 


【 例 3.10】《 实 例文 件 ，ch033.10.php) 


<?php 
$int1= 2012; // 十 进 制 整数 
$int2= 01223; // 八 进 制 整数 
S$int3=0x1223; ”// 十 六 进 制 整 数 
echo "输出 整数 类 型 的 值 : "; 
echo $intl; 
echo "\t"; // 输 出 一 个 制 表 符 
echo $int2;  // 输 出 659 
echo "NE 
echo $int3;  // 输 出 4643 
echo "<br />"; 
$float1l=54.66; 
echo $float1l; ” // 输 出 54.66 
echo "<br />"; 
echo "输出 布尔 型 变量 : "; 
echo (Boolean) ( $int1);  // 将 intl 整 型 转化 为 布尔 变量 
echo "<br />"; 
$stringl1=" 字 符 串 类 型 的 变量 "， 
echo $stringl; 

?> 


本 程序 运行 结果 如 图 3-10 所 示 。 








| Shocahost Pp ~ BO x | gxanem 
诡 件 丰 坊 ) 玛 看 | #8 六) 工具 (Tm) 天 B(H| 


输出 整数 类 型 的 值 ，2012 659 4543 
54.65 


箱 出 布尔 型 变量 : 1 
字符 串 类 型 的 变量 














图 3-10 程序 运行 结果 


3.5.6 ”数组 型 Carray) 


数组 是 PHP 变量 的 集合 ， 它 是 按照 “ 键 值 ”与 “ 值 ”的 对 应 关系 组 织 数据 的 。 数 组 的 键 值 可 
以 是 整数 ,也 可 以 是 字符 串 。 另外， 数组 不 特意 表明 键 值 的 默认 情况 下 ,数组 元 素 的 键 值 为 从 零 开 


始 的 整数 。 
在 PHP 中 ， 使 用 list0 函 数 或 array() 函 数 来 创建 数组 ， 也 可 以 直接 进行 赋值 。 
下 面 使 用 aray0 函 数 创建 数组 。 
【 例 3.11】 《实例 文件 : ch033.11.php) 


<?php 
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本 程序 运行 结果 如 图 3-11 所 示 。 





3-11 程序 运行 结果 
【案例 分 析 】: 


(1) 程序 中 用 “=>” 为 数组 赋值 ， 数 组 的 下 标 只 是 存储 的 标识 ， 没 有 任何 意义 ， 数 组 元 素 的 
排列 以 加 入 的 先后 顺序 为 准 。 

(2) 本 程序 采用 for 循环 语句 输出 整个 数组 ， 其 中 count 函数 返回 数组 的 个 数 ，echo 函数 返 
回 当前 数组 指针 的 索引 值 对 ， 后 面 的 章节 将 详细 讲述 echo 函数 的 使 用 方法 。 

上 面 实例 的 语句 可 以 简化 如 下 。 

【 例 3.12】 (实例 文件 : ch03\3.12.php) 





本 程序 运行 结果 如 图 3-12 所 示 。 从 结果 可 以 看 出 ， 这 两 种 写法 的 运行 结果 相同 。 
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15 
100000 
开始 学 习 PHP 基 本 语法 了 








图 3-12 程序 运行 结果 


另外 ， 读 者 还 可 以 对 数组 的 元 素 一 个 一 个 地 赋值 ， 下 面 举例 说 明 。 上 面 的 语句 可 以 简化 如 下 。 
【 例 3.13】〔 实 例文 件 ，ch033.13.php) 


<?php 
$arr[0]=15; // 对 数组 元 素 分 别 赋值 
$arr[2]= 1E+05; 


$arr [1]= "开始 学 习 PHP 基本 语法 了 "; 


for ($i=0;$i<count ($arr);$i++) 
上 


$arrl=each ($arr); 


echo "$arrl [value] <br />"; 
} 
i 


本 程序 运行 结果 如 图 3-13 所 示 。 从 结果 可 以 看 出 ， 一 个 一 个 赋值 的 方法 和 上 面 两 种 写法 的 运 
行 结 果 一 样 。 
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图 3-13 程序 运行 结果 
3.5.7 ”对 象 型 (object) 


对 象 就 是 类 的 实例 。 当 一 个 类 被 实例 化 以 后 ， 这 个 被 生成 的 对 象 被 传递 给 一 个 变量 ， 这 个 变 
量 就 是 对 象 型 变量 。 对 象 型 变量 也 属于 资源 型 变量 。 
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3.5.8 NULL 型 

NULL 类 型 是 仅 拥有 NULL 这 个 值 的 类 型 。 这 个 类 型 用 来 标记 一 个 变量 为 空 。 一 个 空 字符 串 
与 NULL 是 不 同 的 。 在 数据 库存 储 时 会 把 空 字符 串 和 NULL 区 分 开 处 理 。NULL 型 在 布尔 判断 时 
永远 为 false。 很 多 情况 下 , 在 声明 一 个 变量 的 时 候 可 以 直接 先 赋值 为 NULL 型 , 如 $value = NULL。 
3.5.9 资源 类 型 (resource ) 

Resource 类 型 ， 也 就 是 资源 类 型 ， 是 十 分 特殊 的 数据 类 型 。 它 表示 PHP 的 扩展 资源 ， 可 以 是 

个 打开 的 文件 ， 也 可 以 是 一 个 数据 库 连 接 ， 甚 至 可 以 是 其 他 的 数据 类 型 。 但 是 在 编程 过 程 中 ， 资 

源 类 型 却 是 几乎 永远 接触 不 到 的 。 
3.5.10 ”数据 类 型 之 间 的 相互 转换 

数据 从 一 种 类 型 转换 到 另外 一 种 类 型 ， 就 是 数据 类 型 转换 。 在 PHP 语言 中 ， 有 两 种 常见 的 转 
换 方式 : 自动 数据 类 型 转换 和 强制 数据 类 型 转换 。 

1. 自动 数据 类 型 转换 

这 种 转换 方法 最 为 常用 ,直接 输入 数据 的 转换 类 型 即 可 。 例 如 float 型 转换 为 整数 int 型 ， 小 数 
点 后 面 的 数 将 被 舍弃 。 如 果 float 数值 超过 了 整数 的 取 值 范围 ， 则 结果 可 能 是 0 或 者 整数 的 最 小 负 
数 。 

【 例 3.14】 (实例 文件 :ch03\3.14.php) 














<?php 
$f1l01=1.86; // 定义 float 类 型 
echo (int)$flol."<br />"; /1/ 转换 为 整数 类 型 输出 
$f£102=4E32; // 超过 整数 取 值 范 围 


echo (int) $flo2; 
2 


本 程序 运行 结果 如 图 3-14 所 示 。 
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图 3-14 程序 运行 结果 
2. 强制 数据 类 型 转换 
在 PHP 中 ， 可 以 使 用 settype 函数 强制 转换 数据 类 型 ， 基 本 语法 如 下 。 


Bool settypel(var,string type) 
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注意 : type 的 可 能 值 不 能 包含 资源 类 型 数据 。 
【 例 3.15】 《实例 文件 :ch03\3.15.php) 
<?php 
$f101=1.86; // 定义 浮 点 型 数据 
echo settype ($flol,"int"); 强制 转换 数据 为 整数 并 输出 


全 


本 程序 运行 结果 如 图 3-15 所 示 。 
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文件 (F) 。 编 句 (E) 。 坦 看 (V) ” 收 若 夹 (A) 工具 (T) 帮助 (H) 
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图 3-15 程序 运行 结果 


3.6 ”标量 类 型 的 声明 


默认 情况 下 ， 所 有 的 PHP 文件 都 处 于 弱 类 型 校 验 模式 。PHP 7 加 了 标量 类 型 声明 的 特性 ， 标 
量 类 型 声明 有 两 种 模式 : 强制 模式 《默认 ) 和 严格 模式 。 

标量 类 型 声明 语法 格式 如 下 : 

declare (Strict types=1); 


通过 指定 strict_ types 的 值 〈1 或 者 0) ，1 表示 严格 类 型 校 验 模式 ， 作 用 于 函数 调用 和 返回 语 
人 句 ; 0 表示 弱 类 型 校 验 模式 。 


C0 可 以 声明 标量 类 型 的 参数 类 型 包括 int、 float、 bool、 string、 interfaces、 array 和 callable。 
提 示 

1. 强制 模式 

下 面 通过 案例 来 学 习 强 制 模式 的 含义 ， 代 码 如 下 : 

<?php 

// 强制 模式 

function sum(int $ints) 

1 

return array sum($ints); 
1 


print(laun(2r "3, A 1)Ys 
?> 


上 面 程序 输出 结果 为 9。 代码 中 的 4.1 先 转换 为 整数 4， 然 后 再 进行 相 加 操作 。 
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2. 严格 模式 
下 面 通过 案例 来 学 习 严格 模式 的 含义 ， 代 码 如 下 : 
<?php 
// 严格 模式 
declare(strict types=1); 
function sum(int S$ints) 
return array sum($ints); 
L 
Print(sum(2， '3', 4.1)); 
?> 


以 上 程序 由 于 采用 了 严格 模式 ， 所 以 如 果 参 数 中 出 现 不 是 整数 的 类 型 ， 程 序 执行 时 会 报错 。 


3.7 ”运算 符 


PHP 包含 多 种 类 型 的 运算 符 ， 常 见 的 有 算术 运算 符 、 字 符 串 运 算 符 、 赋 值 运算 符 、 比 较 运算 
符 和 迪 辑 运算 符 等 
3.7.1 算术 运算 符 

算术 运算 符 是 最 简单 ， 也 是 最 常用 的 运算 符 。 常 见 的 算术 运算 符 如 表 3-1 所 示 。 


表 3-1 常见 的 算术 运算 符 
运算 符 名 称 

EE 
| 


| | 除法 运算 符 
| 
和 
累 减 运算 符 


算术 运算 符 的 用 法 如 下 面 的 实例 所 示 。 
【 例 3.16】 “实例 文件 :ch03\3.16.php) 


<?php 
$a=13; / 定义 变量 
$b=2; 
echo $a."+".$b."="; 
echo $at$b."<br />"; // 使 用 加 法 运算 符 
echo $a."—".$b."="; 
echo $a-$b."<br />"; // 使 用 减法 运算 符 
echo $a."*".$Db."="; 
echo $a*$b."<br />"; // 使 用 乘法 运算 符 


echo $a."/".$b."="; 
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echo $a/$b."<br />"; // 使 用 除法 运算 符 
echo $a."%®".$b."="; 

echo $a%s$b."<br />"; // 使 用 求 余 运算 符 
echo Sa"tin "en 

echo $at+."<br />"; // 使 用 累加 运算 符 
echo 各 一 一 下 "my 


echo $a--."<br />"; // 使 用 累 减 运算 符 


本 程序 运行 结果 如 图 3-16 所 示 。 








国 j rweanox P - Bo x [BERS 
文件 由 淹 EE] 豆 看 0) 收 基 夫 (入 工具 (大 劲 (H) 























13+2=15 
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图 3-16 程序 运行 结果 


@! 除了 数值 可 以 进行 自 增 运算 外 ， 字 符 也 可 以 进行 自 增 运算 操作 。 例 如 b++， 结 果 将 等 


提示 了 
3.7.2 ”字符 串 运 算 符 


字符 串 运 算 符 是 把 两 个 字符 串 连接 起 来 变 成 一 个 字符 串 的 运算 符 ， 使 用 “.” 来 完成 。 如 果 变 
量 是 整 型 或 浮 点 型 ，PHP 也 会 自动 把 它们 转换 为 字符 串 输出 ， 如 下 面 的 实例 所 示 。 
【 例 3.17】 “实例 文件 :ch03\3.17.php ) 


<?php 
$a = "把 两 个 字符 串 " / 定义 字符 串 变 量 
$b = 10.25; 
echo $a." 连 接 起 来 ，" .$b." 天 。"; // 把 字符 串 连 接 后 输出 
?> 


本 程序 运行 结果 如 图 3-17 所 示 。 


[¢ 问 @ hnpylocalhost PD ~ BO Xx |G AE 


文件 (F)” 妨 加 (E) 查看 V) 收藏 闪 (A) 工具 (T) 帮助 (H) 























把 两 个 字符 串 连 接 起 来 ，10. 25 天 - 








3-17 程序 运行 结果 
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3.7.3 ”赋值 运算 符 
赋值 运算 符 的 作用 是 把 一 定 的 数据 值 加 载 给 特定 变量 。 
赋值 运算 符 的 具体 含义 如 表 3-2 所 示 。 
表 3-2 赋值 运算 符 的 含义 
赋值 运算 符 
将 右边 的 值 赋值 给 左边 的 变量 
| 将 左边 的 值 加 上 右边 的 值 赋 给 左边 的 变量 
将 左边 的 值 减 去 右边 的 值 赋 给 左边 的 变量 








将 左边 的 值 乘 以 右边 的 值 赋 给 左边 的 变量 
| 将 左边 的 值 除 以 右边 的 值 赋 给 左边 的 变量 
将 左边 的 字符 串 连 接 到 右边 


将 左边 的 值 对 右边 的 值 取 余数 赋 给 左边 的 变量 











例如 ，$a-=$b 等 价 于 $a=$a-$b， 其 他 赋值 运算 符 与 之 类 似 。 从 上 表 可 以 看 出 ,赋值 运算 符 可 以 
使 程序 更 加 简练 ， 从 而 提高 执行 效率 。 


3.7.4 ”比较 运算 符 
比较 运算 符 用 来 比较 其 两 端 数据 值 的 大 小 。 比 较 运算 符 的 具体 含义 如 表 3-3 所 示 。 


表 3-3 ”比较 运算 符 的 含义 
比较 运算 符 含义 
一 相等 
! = 不 相等 
> 和 
< 小 于 
>= 大 于 等 于 
<= 小 于 等 于 
一 = 精确 等 于 〈 类 型 也 要 相同 ) 
伍 不 精确 等 于 


其 中 ，“ 一 -” 和 “!I==” 需 要 特别 注意 一 下 。$b= 一 $c 表示 $b 和 $c 不 只 是 数值 上 相等 ， 而 且 
两 者 的 类 型 也 一 样 ，$b! 一 $c 表示 $b 和 $c 有 可 能 是 数值 不 等 ， 也 可 能 是 类 型 不 同 。 
【 例 3.18】 “实例 文件 ，ch03\3.18.php) 
<?PHP 
$value="15"; 
echo "\$value = \"$value\""; 
echo "\$value==15: "; 








var_dump ($value==15); // 结 果 为 :bool (true) 
echo "\S$value==ture: "; 
var_dump ($value==false); // 结 果 为 :bool (false) 


echo "\S$value!=nul1: "; 
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Var_dump (S$value!=nul1) // 结 果 为 :bool (true) 
echo "\$value==false: "7 
var_dump ($value==false); // 结 果 为 :bool (false) 


echo "\$value 
var_dump ($value===100); // 结 果 为 :bool (false) 
echo "\$value===true: "; 

var_dump ($value===true); // 结 果 为 :bool (false) 
echo "(10/2.0 ! 
var dump (10/2.0 !==5); // 结 果 为 :bool (true) 
> 


本 程序 运行 结果 如 图 3-18 所 示 。 



































Svalue = "15"15==15: 


caveh0av3a.18.phpil0tbeclean true 
Svalue==ture: 
cavch93\3.19 .Phpi12tbeclean faloe 
Svalue!=null: 


Ci\cho3\3.1 





hp:14:bcolean true 
Svalue==false: 
Cc:\cho3\3.18.php:16:boclean false 


Svalue — 15: 





Civch03\3.18.php:18:bccleal 
Svalue—true: 
csveh0a\a.18.Ehp:20:beolean false 
5); 


Cr\ch03\3.18.php:22:5oolean true 





(10/2.0! 











图 3-18 程序 运行 结果 
3.7.5 ”逻辑 运算 符 
编程 语言 最 重要 的 功能 之 一 就 是 进行 逻辑 判断 和 运算 。 罗 辑 和 、 逻 辑 或 、 罗 辑 否 都 是 多 辑 运 
算 符 。 逻 辑 运算 符 的 含义 如 表 3-4 所 示 。 
表 3-4 ”逻辑 运算 的 含义 
逻辑 运算 符 
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【 例 3.19】《 实 例文 件 :ch03\3.19.php) 


<?php 
$a = true; 
$b = false; 
echo '$a && Sb: '; 
var_dump (Sa && $b); // 使 用 逻辑 与 运算 符 ， 结 果 为 : false 
acho, "$a Il Sb "> 
var dump($a || $b); // 使 用 逻辑 或 运算 符 ， 结 果 为 :true 
echo "! Sa 
var dump($a && $b); // 使 用 逻辑 否 运算 符 ， 结 果 为 :false 


本 程序 运行 结果 如 图 3-19 所 示 。 























司 | 四 -JE@ neoc B p+ ©| Glocahor 
文件 中 编 龟 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) ”帮助 (H) 
Sa && Sb: 

















C: \wamp\www\ch03\3. 19. php:5:boolean false 
Sa $b: 
Cl \wamp\www\ch03\3. 19. php:7:boolean true 


! $a: 


C: \wamp\www\ch03\3. 19. php:9:boolean false 


图 3-19 程序 运行 结果 
3.7.6 ” 按 位 运算 符 
按 位 运算 符 ， 是 把 整数 按照 “位 ”的 单位 来 进行 处 理 。 按 位 运算 符 的 含义 如 表 3-5 所 示 。 
表 3-5 按 位 运算 符 的 含义 


按 位 运算 符 名 称 


& 按 位 和 例如 Sa&Sb， 表 示 对 应 位 数 都 为 1， 则 结果 改 位 为 1 
| 折 例如 SalSb， 表 示 对 应 位 数 有 一 个 为 1， 则 结果 改 位 为 1 





例如 Sa^Sb， 表 示 对 应 位 数 不 同 ， 则 结果 改 位 为 1 

例如 ~Sb， 表 示 对 应 位 数 为 0 的 改 为 1， 为 1 的 改 为 0 

例如 Sa<<Sb， 表 示 将 Sa 在 内 存 中 二 进 制 数 据 向 左 移动 Sb 位 数 ， 右 边 移 空 补 0 | 
例如 Sa>>$b， 表 示 将 $a 在 内 存 中 二 进 制 数据 向 右 移动 $b 位 数 ， 左 边 移 空 补 0 














【 例 3.20】 《实例 文件 :ch03\3.20.php) 


<?php 

Sa = 7; // 7 的 二 进 制 代码 是 111 

$b = 4; // 4 的 二 进 制 代 码 是 100 

echo '$Sa&g $bD="' . ($ag $b) . '<br/>'; // 运算 结果 为 二 进 制 代 码 100， 即 4 


echo '$a | $b=" . ($al $b) . '<br/>'; // 运算 结果 为 二 进 制 代码 111， 即 7 
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EcosanSESaC SD) "<bz/> ;77 运算 结果 为 = 进 制 代码 011,， 即 3 


> 


本 程序 运行 结果 如 图 3-20 所 示 。 











全 http://localhost/ch03 PD ~ © @ localhost 
文件 (月 ”编辑 (E) ”前 看 (V) ”收藏 夫 (A) ”工具 (D ”帮助 (H) 














Sa& Sb=4 


Sal$Sb=7 
Sa 人 ^Sb=3 





图 3-20 程序 运行 结果 
3.7.7 ”否定 控制 运算 符 
否定 控制 运算 符 用 在 “操作 数 ” 之 前 ， 用 于 对 操作 数值 进行 真 假 的 判断 。 它 包含 一 个 迪 辑 否 
定 运算 符 和 一 个 按 位 否定 运算 符 。 否 定 控制 运算 符 的 含义 如 表 3-6 所 示 。 
表 3-6 否定 控制 运算 符 的 含义 
否定 控制 运算 符 





3.7.8 ”错误 控制 运算 符 
错误 控制 运算 符 用 “@” 来 表示 。 在 一 个 操作 数 之 前 使 用 ， 用 来 屏蔽 错误 信息 的 生成 。 
【 例 3.21】 《实例 文件 ，ch03\3.21.php) 
<?php 
$err = @(20 / 0) ; // 如 果 不 想 显示 这 个 错误 , 在 表达 式 前 加 上 “@” 


季 


本 程序 运行 结果 如 图 3-21 所 示 。 








铺 htp://localhost/eh03 P * CB localhost 


文件 (有 ) ”篇 强 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 




















图 3-21 程序 运行 结果 
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3.7.9 三 元 运算 符 

三 元 运算 符 作用 在 三 个 操作 数 之 间 。 这 样 的 操作 符 在 PHP 中 只 有 一 个 ， 即 “? : ”， 语 法 形 
式 如 下 : 

(expr1l) ? (expr2): (expr3) 

如 果 exprl 成 立 ， 则 执行 expr2， 否 则 执行 expr3 。 

【 例 3.22】《 实 例文 件 ，ch03\3.22.php) 

<?php 

Sa = 5; 

Sb = 6; 

echo ($a > $b) 2?" 大 于 成 立 ”': "大 于 不 成 立 "echo "<br/>"; // 大 于 不 成 立 

echo ($a < $bp) ?“" 小 于 成 立 ”: "小 于 不 成 立 "; echo "<br/>"; // 小 于 成 立 


?> 


本 程序 运行 结果 如 图 3-22 所 示 。 





OS @ httpi//localhost/cho3 PD = © | Elocalhost 


文件 (月 ” 编 铝 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 














大 于 不 成 立 
小 于 成 立 





图 3-22 程序 运行 结果 


3.7.10 ”运算 符 的 优先 级 和 结合 规则 
运算 符 的 优先 级 和 结合 其 实 与 正常 的 数学 运算 符 的 规则 十 分 相似 。 
@ ”加 减 来 除 的 先后 顺序 同 数学 运算 中 的 完全 一 致 。 


@ ”对 于 括号 ， 则 先 括 号 内 再 括号 外 。 
@ ”对 于 赋值 ， 则 由 右 向 左 运 行 ， 即 值 依次 从 右边 向 左边 的 变量 进行 赋值 。 


3.8 表达 式 


表达 式 是 在 特定 语言 中 表达 一 个 特定 的 操作 或 动作 的 语句 。PHP 的 表达 式 也 有 同样 的 作用 。 

一 个 表达 式 包 含 “ 操 作 数 ”和 “操作 符 ”。 操 作 数 可 以 是 变量 ， 也 可 以 是 常量 。 操 作 符 则 体 
现 了 要 表达 的 各 个 行为 ， 如 逻辑 判断 、 赋 值 、 运 算 等 。 

例如 $a=5 就 是 表达 式 ， 而 $a=5; 则 为 语句 。 另 外 ， 表 达 式 也 有 值 ， 例 如 $a=1 表达 式 的 值 为 1。 


【六 在 PHP 代码 中 ,使 用 “” 号 来 区 分 表达 式 ， 即 一 个 表达 式 和 一 个 分 号 组 成 了 一 条 PHP 


语句 。 在 编写 代码 程序 时 ， 应 该 特别 注意 表达 式 后 面 的 “;”， 不 要 漏 写 或 写 错 ， 否 则 
提 示 。 会 提示 语法 错误 。 
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3.9 ”实战 演练 一 一 创建 多 维 数组 


前 面 讲述 了 如 何 创建 一 维 数组 ， 本 节 讲 述 如 何 创 建 多 维 数组 。 多 维 数组 和 一 维 数组 的 区 别 是 
多 维 数组 有 两 个 或 多 个 下 标 ， 它 们 的 用 法 基本 相似 。 
下 面 以 创建 二 维 数组 为 例 进行 讲解 。 
【 例 3.23】 (实例 文件 ，ch03\3.23.php) 
<?php 
$arr[0][0]=10; // 定 义 数组 元 素 并 赋值 
$arr [0] [1]=22; 
Sarr[1] [0]=1E+05; 
$arr [1] [1]= "开始 学 习 PHP 基本 语法 了 "; 
for ($i=0;$i<count ($arr); $i++) /使 用 for 语句 输出 二 维 数 组 


for ($k=0;$k<count ($arr [$i]);$k++) 
{ 
$arrl=each ($arr[$i]); 
echo "$arrl[value]<br />"; 
} 
} 


?> 


本 程序 运行 结果 如 图 3-23 所 示 。 





[=-[e ee 
站 hp/ocalhost p - cx| BE -wma | 
文件 (站 江 加 (E) ” 王 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 





100000 
开始 学 习 PHP 基 本 语法 了 








或 100% ~ 


图 3-23 程序 运行 结果 





3.10 ”高 手 私房 菜 
技巧 1: 如 何 灵活 运用 命名 空间 (namespace) ? 


命名 空间 (namespace) 作为 一 个 比较 宽泛 的 概念 ， 可 以 理解 为 用 来 封装 各 个 项 目的 方法 。 有 
点 像 是 在 文件 系统 中 不 同文 件 夹 路 径 和 文件 夹 当中 的 文件 。 两 个 文件 的 文件 名 可 以 完全 相同 , 但 是 
在 不 同 的 文件 夹 路 径 下 ， 就 是 两 个 完全 不 同 的 文件 。 
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PHP 的 命名 空间 也 是 这 样 的 一 个 概念 。 它 主要 用 于 在 “类 的 命名 ”、“ 函 数 命名 ”及 “常量 
命名 ”中 避免 代码 冲突 和 在 命名 空间 下 管理 变量 名 和 常量 名 。 

命名 空间 是 使 用 namespace 关键 字 在 文件 头 部 定义 的 ， 例 如 : 

<?php 

namespace 2ndbuilding\number24; // 命 名 空间 

class room{} 

Sroom = new __ NAMESPACE .room; 

?> 


命名 空间 还 可 以 拥有 子 空间 ， 就 像 文件 夹 的 路 径 一 样 。 可 以 通过 内 置 变量 NAMESPACE 来 
使 用 命名 空间 及 其 子 空间 。 
技巧 2: 如 何 快速 区 分 常量 与 变量 ? 
常量 和 变量 的 明显 区 别 如 下 。 
@ 常量 前 面 没有 美元 符号 ($ )。 
常量 只 能 用 define() 函数 定义 ， 而 不 能 通过 赋值 语句 定义 。 
常量 可 以 不 用 理会 变量 范围 的 规则 而 在 任何 地 方 定义 和 访问 。 
常量 一 旦 定义 就 不 能 被 重新 定义 或 者 取消 定义 。 
常量 的 值 只 能 是 标量 。 


3.11 经 典 习题 


(1) 制作 一 个 包含 常量 的 例子 ， 输 出 当前 文件 的 路 径 。 

(2) 制作 一 个 包含 变量 的 例子 ， 分 析 变 量 引 用 前 和 引用 后 的 变化 。 
(3) 制作 一 个 包含 数据 类 型 之 间 的 相互 转换 的 例子 。 

(4) 制作 一 个 包含 一 维 数组 和 多 位 数组 的 例子 。 


第 4 章 PHP 语言 结构 


在 任何 一 种 语言 中 ， 都 有 程序 结构 ， 常 见 的 有 顺序 结构 、 分 支 结 构 和 循环 结构 。 在 学 习 程序 
结构 前 ， 读 者 还 需要 对 函数 的 知识 进行 学 习 。 本 章 主要 介绍 PHP 语言 中 函数 和 语言 结构 的 使 用 方 
法 和 技巧 。 

本 章 学 习 目标 

@ 熟悉 函数 的 使 用 方法 
熟悉 流程 控制 的 概述 
掌握 条 件 控制 结构 
掌握 循环 控制 结构 
掌握 条 件 分 支 结构 的 综合 应 用 
掌握 循环 控制 结构 的 综合 应 用 


4.1 内 置 函 数 


函数 的 英文 为 function"，function 是 功能 的 意思 。 顾 名 思 义 ， 使 用 函数 就 是 要 在 编程 过 程 中 实 
现 一 定 的 功能 , 即 通过 代码 块 来 实现 一 定 的 功能 。 比 如 通过 一 定 的 功能 记录 下 酒店 客人 的 个 人 信息 ， 
每 到 他 生日 的 时 候 自动 给 他 发 送 祝贺 email， 并 且 这 个 发 信 “ 功 能 ”可 以 重用 ， 可 更 改 为 在 某 个 客 
户 的 结婚 纪念 日 时 给 他 发 送 祝福 email。 所 以 函数 就 是 实现 一 定 功能 的 一 段 特定 的 代码 。 

PHP 提供 了 大 量 的 内 置 函 数 ， 方 便 程序 员 直 接 使 用 ， 常 见 的 内 置 函数 包 插 数学 函数 、 字 符 串 
函数 、 时 间 和 日 期 函数 等 。 

下 面 以 调用 数学 函数 rand() 为 例 进 行 讲解 。 

【 例 4.1】〔 实 例文 件 ，ch04\4.1.php) 


<?php 

echo rand ().”<br />”; // 返 回 随机 整合 

echo rand (1000,9999) .“<br />”; // 产 生 一 个 4 位 随机 整数 
?> 


本 程序 运行 结果 如 图 4-1 所 示 。 




















Ee 
BO htp//oca B DP | localhost “| 有 吧 
文件 (月 编 疆 (E] ”二 看 (V) 收藏 夫 (A) 工具 (T 帮助 (H) 
16765 
3843 








图 4-1 程序 运行 结果 
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4.2 自 定义 函数 
其 实 ， 更 多 的 情况 下 ， 程 序 员 需 要 的 是 自 定义 函数 。 


4.2.1 自 定 义 和 调 用 函数 
自 定义 函数 的 语法 结构 如 下 : 


function name of _ function( paraml, param2, .. ){ 
statement 
} 
其 中 name_of function 是 函数 名 ，param1、param2 是 参数 ，statement 是 函数 的 具体 内 容 。 
下 面 以 自 定义 和 调用 函数 为 例 进行 讲解 。 本 实例 主要 实现 酒店 欢迎 信息 。 
【 例 4.2】《〈 实 例文 件 ，ch04\4.2.php) 


<?php 


function sayhello($customer){ // 自 定义 函数 sayhello 
return $customer."， 欢 迎 您 来 到 GoodHome 酒店 。"; 
} 
echo sayhello(' 张 先生 ')， // 调 用 函数 sayhello 
人 


本 程序 运行 结果 如 图 4-2 所 示 。 











Je newoecehos p ~ BO x | Blocalhost 


文件 ()” 妨 错 (E) 下 看 (V) 收藏 只 (A】 工具 (Tm 。 帮助 (H) 
张 先生 ， 欢 迎 您 来 到 GoodHome 酒 店 。 








图 4-2 程序 运行 结果 


值得 一 提 的 是 , 此 函数 的 返回 值 是 通过 值 返回 的 。 也 就 是 说 return 语句 返回 值 时 , 创建 了 一 个 
值 的 拷贝 ， 并 把 它 返 回 给 使 用 此 函数 的 命令 或 函数 ， 在 这 里 是 echo 命令 。 


4.2.2 向 函数 传递 参数 值 
由 于 函数 是 一 段 封 闭 的 程序 ， 很 多 时 候 ， 程 序 员 都 需要 向 函数 内 传递 一 些 数据 来 进行 操作 。 


function 函数 名 称 〈 参 数 1， 参 数 2) { 
算法 描述 ， 其 中 使 用 参数 1 和 参数 2; 
} 
下 面 以 计算 酒店 房间 住宿 费 总 价 为 例 进行 讲解 。 
【 例 4.3】〔 实 例文 件 ，ch04\4.3.php) 


<?php 
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function totalneedtopay(S$days,Sroomprice){ // 声明 自 定 义 函 数 
Stotalcost = $days*$roomprice; // 计算 住宿 费 总 价 
echo "需要 支付 的 总 价 :$totalcost"." 元 。"; // 计算 住宿 费 总 价 
} 


Srentdays = 3; // 声 明 全 局 变量 
Sroomprice = 168; 
totalneedtopay ($rentdays, $roomprice); // 通 过 变量 传递 参数 


totalneedtopay (5,198); // 直 接 传递 参数 值 
?> 


运行 结果 如 图 4-3 所 示 。 
































ttpi//localhost PD - CX| Elocalhost 
文件 (D。 编 锯 (FE) 误 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


需要 支付 的 总 价 : 504 元 。 需 要 支付 的 总 价 : 990 元 。 














图 4-3 程序 运行 结果 


【案例 分 析 】: 


(1) 以 这 种 方式 传递 参数 值 的 方法 就 是 向 函数 传递 参数 值 。 

(2) 其 中 function totalneedtopay($days,$roomprice) 们 定义 了 函数 和 参数 。 

(3) 不 管 是 通过 变量 $rentdays 和 $roomprice 向 函数 内 传递 参数 值 , 还 是 像 totalneedtopay (5,198) 
这 样 直接 传递 参数 值 都 是 一 样 的 。 


4.2.3 向 函数 传递 参数 引用 


向 函数 传递 参数 引用 ， 其 实 就 是 向 函数 传递 变量 引用 。 参 数 引 用 一 定 是 变量 引用 ， 静 态 数值 
是 没有 引用 一 说 的 。 由 于 在 变量 引用 中 已 经 知道 ,变量 引用 其 实 就 是 对 变量 名 的 使 用 ,是 对 特定 的 
变量 位 置 的 使 用 。 

下 面 仍 然 以 计算 酒店 服务 费 总 价 为 例 进行 讲解 。 

【 例 4.4】〔 实 例文 件 ，ch04\4.4.php) 


<?php 

$fee = 300; 

$serviceprice = 50; 

function totalfee (&$fee, $serviceprice){ // 声明 自 定义 函数 ， 参 数 前 多 了 &， 表 示 
按 引用 传递 

$fee = $feet$serviceprice; // 改变 形 参 的 值 ， 实 参 的 值 也 会 发 生 改 变 
echo "需要 支付 的 总 价 : $fee" ." 元 。"; 
} 


totalfee ($fee, $serviceprice); /V/ 函 数 外 部 调用 fun () 函数 前 $fee =300 
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// 函 数 外 部 调用 fun () 函数 后 $ fee =350 


totalfee ($fee, $serviceprice); 
ee 


运行 结果 如 图 44 所 示 。 
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需要 支付 的 总 价 :350 元 ， 需 要 支付 的 总 价 ;400 元- 








图 4-4 程序 运行 结果 


【案例 分 析 】: 

(1) 以 这 种 方式 传递 参数 值 的 方法 就 是 向 函数 传递 参数 引用 。 使 用 “&” 符 号 表示 参数 引用 。 

(2) 其 中 function totalfee(&$fee,$serviceprice) 们 定义 了 函数 、 参 数 和 参数 引用 。 变 量 $fee 是 
以 参数 引用 的 方式 进入 函数 的 。 当 函数 的 运行 结果 改变 了 变量 $fee 的 引用 的 时 候 , 在 函数 外 的 变量 
$fee 的 值 也 发 生 了 改变 ， 也 就 是 函数 改变 了 外 部 变量 的 值 。 


4.2.4 从 函数 中 返回 值 

以 上 的 例子 中 ， 都 是 把 函数 运算 完成 的 值 直接 打印 出 来 。 但 是 ， 很 多 情况 下 ， 程 序 并 不 需要 
直接 把 结果 打印 出 来 ， 而 是 仅仅 给 出 结果 ， 并 且 把 结果 传递 给 调用 这 个 函数 的 程序 ， 为 其 所 用 。 
这 里 需要 用 到 return 关键 字 。 下 面 以 综合 酒店 客房 价格 和 服务 价格 为 例 进行 讲解 。 

【 例 4.5】 实 例文 件 : ch04\4.5.php) 





<?php 
function totalneedtopay ($days, Sroomprice){ // 声明 自 定义 函数 


return $days*$roomprice; // 返回 酒店 消费 总 价格 


} 

Srentdays = 3; 

Sroomprice = 168; 

echo totalneedtopay ($rentdays,$roomprice); 


en 


运行 结果 如 图 4-5 所 示 。 


本 
《Gilereewao- B06 x||@ localhost 


文件 (月 ” 妨 缠 (E) 查看 (V) 收藏 夫 (A) 工具 (D 帮助 (H) 




















504 








4-5 程序 运行 结果 
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【案例 分 析 】 : 
(1) 在 函数 function totalneedtopay($days,Sroomprice) 算 法 中 ， 直 接 使 用 return 把 运算 的 值 返 
回 给 调用 此 函数 的 程序 。 


(2) 其 中 echo totalneedtopay($rentdays,$roomprice); 语 句 调 用 了 此 函数 ，totalneedtopay() 把 运 
算 值 返回 给 了 echo 语句 ， 才 有 上 面 的 显示 。 当 然 这 里 也 可 以 不 用 echo 来 处 理 返 回 值 ， 也 可 以 对 它 
进行 其 他 处 理 ， 比 如 赋值 给 变量 等 。 


4.2.5 “对 函数 的 引用 
不 管 是 PHP 中 的 内 置 函 数 ， 还 是 程序 员 在 程序 中 自 定义 的 函数 ， 都 可 以 简单 地 通过 函数 名 调 
用 。 但 是 操作 过 程 也 有 些 不 同 ， 大 致 分 为 以 下 3 种 情况 。 
@ ”如果 是 PHP 的 内 置 函数 ， 如 date()， 可 以 直接 调用 。 
@ 如 果 这 个 函数 是 PHP 的 某 个 库 文 件 中 的 函数 ， 则 需要 用 include() 或 require() 命 令 把 此 库 
文件 加 载 ， 然 后 才能 使 用 。 
@ 如果 是 自 定义 函数 ， 如 果 与 引用 程序 同 在 一 个 文件 中 ， 则 可 直接 引用 。 如 果 此 函数 不 在 
当前 文件 内 ， 则 需要 用 include() 或 require0 命 令 加 载 。 


对 函数 的 引用 ， 实 际 上 是 对 函数 返回 值 的 引用 。 
【 例 4.6】 实例 文件 : ch04\4.6.php) 

















<?php 
function gexample($aa=1){ // 定 义 一 个 函数 ， 别 忘 了 加 “&” 符 号 
return $aa; // 返 回 参 数 $str 
} 
$bb= &example ("引用 函数 的 实例 "); // 声 明 一 个 函数 的 引用 $str1; 
echo $bb. “<br />™; 
时 过 
运行 结果 如 图 4-6 所 示 。 
[¢ 轿 七 hp//localhost PD» BCX [BS semesm 
文件 (篇 各 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 
引用 函数 的 实例 
图 4-6 程序 运行 结果 
【案例 分 析 】: 
(1) 本 实例 首先 定义 一 个 函数 , 然后 变量 $bb 将 引用 函数 , 最 后 输出 变量 $bb, 它 实 际 上 是 $aa 
的 值 。 





(2) 和 参数 传递 不 同 ， 在 定义 函数 和 引用 函数 时 ， 都 必须 使 用 “&” 符 号 ， 表 明 返 回 的 是 一 
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个 引用 。 
4.2.6 ”对 函数 取消 引用 


对 于 不 需要 引用 的 函数 ， 可 以 做 取消 操作 。 取 消 引用 使 用 unset() 函 数 来 完成 ， 目 的 是 断 开 变 
量 名 和 变量 内 容 之 间 的 绑 定 ， 此 时 并 没有 销毁 变量 内 容 。 
【 例 4.7】《〈 实 例文 件 : ch04\4.7.php) 


<?php 

$num = 166; // 声 明 一 个 整 型 变量 

Smath = &Snumy // 声 明 一 个 对 变量 snum 的 引用 $math 
echo "\Smath is: ".Smath."<br />"; // 输 出 引用 $math 

unset ($math); // 取 消 引 用 $math 

echo "\$num is: ".$num; // 输 出 原 变 量 

We 


运行 结果 如 图 4-7 所 示 。 
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文件 (中 。 编 句 (E) ”查看 (V) 收藏 交 (A) 工具 (T) 。 帮助 (H) 





Smath is: 166 
Snum is: 166 








图 4-7 程序 运行 结果 


本 程序 首先 声明 一 个 变量 和 变量 的 引用 ， 输 出 引用 后 取消 引用 ， 再 次 调用 原 变量 。 从 图 4-6 
可 以 看 出 ， 取 消 引用 后 对 原 变量 没有 任何 影响 。 


4.3 包含 文件 


如 果 想 让 自 定义 的 函数 被 多 个 文件 使 用 ， 可 以 将 自 定义 函数 组 织 到 一 个 或 者 多 个 文件 中 ， 这 
些 收 集 函 数 定义 的 文件 就 是 用 户 自己 创建 的 PHP 函数 库 。 通 过 使 用 require 0 和 include() 等 函数 可 
以 将 函数 库 载 入 到 脚本 程序 中 。 
4.3.1 require 和 include 
require() 和 include() 语 句 不 是 真正 意义 的 函数 ， 属 于 语言 结构 。 通 过 include0 和 require() 语 句 
都 可 以 实现 包含 并 运行 指定 文件 。 
(1) require0: 在 脚本 执行 前 读 入 它 包 含 的 文件 ， 通 常 在 文件 的 开头 和 结尾 处 使 用 。 
(2) include(): 在 脚本 读 到 它 的 时 候 才 将 包含 的 文件 读 进来 ， 通 常 在 流程 控制 的 处 理 区 使 用 。 
require() 和 include() 语 句 对 于 处 理 失 败 方面 是 不 同 的 。 当 文件 读 取 失败 后 ，requie 将 产生 一 个 





。54 。 
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致命 错误 ， 而 include 则 产生 一 个 警告 。 可 见 ， 如 果 遇 到 文件 丢失 时 需要 继续 运行 ， 则 使 用 include， 
如 果 想 停止 处 理 页 面 ， 则 使 用 requie。 
【 例 4.8】〔 实 例文 件 ， ch04\4.8.php 和 test.php) 


其 中 ，4.8.php 代码 如 下 : 
<?php 

$aaa = ' 杨 柳 青 青 江水 平 '; // 定 义 一 个 变量 aaa 
$bbb = ' 闻 郎 江 上 唱歌 声 ';  // 定 义 一 个 变量 bbb 


?> 

test.php 代码 如 下 : 

<?php 

echo " $aaa $bbb";  // 未 载 入 文件 前 调用 两 个 变量 

include '4.8.php'; 

echo " $aaa $bbb "; // 载 入 文件 后 调用 两 个 变量 

运行 test.php 结果 如 图 4-8 所 示 。 从 结果 可 以 看 出 ,使 用 include 时 ,虽然 出 现 了 警告 , 但 是 脚 
本 程序 仍然 在 运行 。 
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图 4-8 程序 运行 结果 
4.3.2 include_once 和 require_once 


include_ once 和 require_once 语句 在 脚本 执行 期 间 包含 并 运行 指定 文件 ， 作 用 与 include 和 
require 语句 类 似 ， 唯 一 的 区 别 是 ， 如 果 该 文件 的 代码 被 包含 了 ， 则 不 会 再 次 包含 ， 只 会 包含 一 次 。 
从 而 避免 函数 重 定义 以 及 变量 重 赋值 等 问题 。 


4.4 流程 控制 概述 
流程 控制 ， 也 叫 控制 结构 ， 在 一 个 应 用 中 用 来 定义 执行 程序 流程 。 它 决定 了 某 个 程序 段 是 否 
会 被 执行 和 执行 多 少 次 。 
PHP 中 的 控制 语句 分 为 3 类 : 顺序 控制 语句 、 条 件 控制 语句 和 循环 控制 语句 。 其 中 顺序 控制 
语句 是 从 上 到 下 依次 执行 的 ， 这 种 结构 没有 分 支 和 循环 ， 是 PHP 程序 中 最 简单 的 结构 。 下 面 主要 
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讲述 条 件 控制 语句 和 循环 控制 语句 。 


4.5 条件 控制 结构 
条 件 控制 语句 中 包含 两 个 主要 的 语句 ， 一 个 是 让 语句 ， 一 个 是 switeh 语句。 
4.5.1 单一 条 件 分 支 结构 (if 语句 ) 
让 语句 是 最 为 常见 的 条 件 控制 语句 ， 它 的 格式 为 
if (条 件 判断 语句) 
命令 执行 语句， 
} 


这 种 形式 只 是 对 一 个 条 件 进行 判断 。 如 果 条 件 成 立 ， 则 执行 命令 语句 ， 否 则 不 执行 。 
让 语句 的 流程 控制 图 如 图 4-9 所 示 。 


[来 ] 
图 4-9 


【 例 4.9】〔 实 例文 件 ，ch04\4.9.php) 
<?php 


让 语句 流程 控制 图 


$num = rand(1,100); 
if ($num $ 2 != 0){ 


// 使 用 rand () 函数 生成 一 个 随机 数 
// 判 断 变 量 $num 是 否 为 奇数 


echo "\$num = $num"; // 如 果 为 奇数 ， 输 出 表达 式 和 说 明文 字 
echo "<br />$num 是 奇数 。"; 

} 

?> 


运行 后 刷新 页 面 ， 结 果 如 图 4-10 所 示 。 
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生生 5 的 信用 
文 作 中 。 等 得 6 下 在) 收 康夫 A) 工具 (大 动 (H) 
Snum = 29 

29 是 奇数 。 








图 4-10 程序 运行 结果 
【案例 分 析 】: 


(1) 此 实例 首先 使 用 rand() 函 数 随机 生成 一 个 整数 Snum, 然后 判断 这 个 随机 整数 是 不 是 奇数 ， 
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如 果 是 ， 则 输出 上 述 结果 ， 如 果 不 是 ， 则 不 输出 任何 内 容 ， 所 以 如 果 页 面 内 容 显示 为 室 ， 则 刷新 页 
面 即 可 。 


(2) rand() 函数 返回 随机 整数 ， 语 法 格式 如 下 : 


rand (min,max) 


此 函数 主要 是 返回 min 和 max 之 间 的 一 个 随机 整数 。 如 果 没 有 提供 可 选 参 数 min 和 max， 


则 rand( 返回 0 到 RAND_MAX 之 间 的 伪 随机 整数 。 
4.5.2 ”双向 条 件 分 支 结构 (if…else 语句 ) 


如 果 是 非 此 即 彼 的 条 件 判断 ， 可 以 使 用 if…else 语句 。 它 的 格式 为 : 
if (条 件 判断 语句 ){ 
命令 执行 语句 R; 
}else{ 
命令 执行 语句 B; 
} 
这 种 结构 形式 首先 判断 条 件 是 否 为 真 ， 如 果 为 真 ， 则 执行 命令 语句 A， 否 则 执行 命令 语句 B。 
if…else 语句 程序 控制 流程 图 如 图 4-11 所 示 。 
[ 开始 
< 


| 程序 块 程序 块 
xs 


图 4-11 if…else 语句 控制 流程 图 
【 例 4.10】 “实例 文件 :ch04\4.10.php) 


<html> 

<?php 

$d=date ("D"); // 定 义 时 间 变 量 

if ($d=="Fri") // 判 断 时 间 变 量 是 否 等 于 周 五 
echo "今天 是 周 五 哦 !"; 

else 
echo "可 惜 今天 不 是 周 五 !"; 

?> 


运行 后 结果 如 图 4-12 所 示 。 
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px 








」 可 惜 今天 不 是 周 五 ! 





图 4-12 程序 运行 结果 
4.5.3 多 向 条 件 分 支 结构 〈elseif 语句 ) 


在 条 件 控制 结构 中 , 有 时 会 出 现 多 于 两 种 的 选择 , 此 时 可 以 使 用 elseif 语句 。 它 的 语法 格式 为 : 
if (条 件 判 断 语句 ){ 


命令 执行 语句 ; 
}elseif (条 件 判断 语句 ) { 

命令 执行 语句 ; 
站 
else{ 

命令 执行 语句 ; 


Fa 
elseif 语句 程序 控制 流程 图 如 图 4-13 所 示 。 


< > 1 全 | n 
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图 4-13 ”elseif 语句 控制 流程 图 
【 例 4.11】 《实例 文件 ，ch04\4.11.php) 






































<?php 

$score = 85; // 设 置 成 绩 变 量 $score 

if ($score >= 0 and $score <= 60){ // 判 断 成 绩 变量 是 否 在 0~60 之 间 

echo "您 的 成 绩 为 差 "7 / /如果 是 ， 说 明成 绩 为 差 

jelseif($score > 60 and $score <= 80){ // 否 则 判断 成 绩 变量 是 否 在 61~80 之 间 
echo "您 的 成 绩 为 中 等 "; // 如 果 是 ， 说 明成 绩 为 中 等 

}else{ // 如 果 两 个 判断 都 是 false， 则 输出 默认 值 
echo "您 的 成 绩 为 优等 "; // 说 明成 绩 为 优等 


} 
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?> 


运行 后 结果 如 图 4-14 所 示 。 








OS 入 hp/ocalhost P - BCx 


文件 (月 ”篇 者 可 看 (V) 收 刘 夫 (A。 工具 帮助 (H) 
您 的 成 绩 为 优等 


图 4-14 程序 运行 结果 
4.5.4 多 向 条 件 分 支 结 构 (switch 语句 ) 
switch 语句 的 结构 给 出 不 同情 况 下 可 能 执行 的 程序 块 ,条 件 满足 哪个 程序 块 ,就 执行 哪个 语句 。 
它 的 语法 格式 为 : 


switch (条 件 判断 语句 ){ 
case 可 能 判断 结果 a: 











命令 执行 语句 ; 
break; 
case 可 能 判断 结果 b: 
命令 执行 语句 ; 
break; 
default: 
命令 执行 语句 ; 


} 
其 中 ， 若 “条 件 判 断 语 句 ” 的 结果 符合 某 个 “可 能 判断 结果 ”， 就 执行 其 对 应 的 “命令 执行 
语句 ”。 如 果 都 不 符合 ， 则 执行 default 对 应 的 默认 项 的 “命令 执行 语句 ”。 
switch 语句 的 流程 控制 图 如 图 4-15 所 示 。 






































图 4-15 switch 语句 控制 流程 图 
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【 例 4.12】〔 实 例文 件 : ch04\4.12.php) 





运行 后 结果 如 图 4-16 所 示 。 


BB Snelocahor P- Box| Go 
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Em 


图 4-16 程序 运行 结果 


4.6 ”循环 控制 结构 


循环 控制 语句 主要 包括 三 种 ， 即 while 循环 、do…while 循环 和 for 循环 。while 循环 在 代码 运 
行 的 开始 检查 表述 的 真 假 ; 而 do…while 循环 则 在 代码 运行 的 末尾 检查 表述 的 真 假 , 这 样 , do…while 


循环 至 少 要 运行 一 遍 。 
4.6.1 ”while 循环 语句 
while 循环 的 结构 为 : 
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其 中 当 “ 条 件 判 断 语句 ”为 true 时 ， 执 行 后 面 的 “命令 执行 语句 ”， 然 后 返回 到 条 件 表达 式 
继续 进行 判断 ， 直 到 表达 式 的 值 为 假 ， 才 能 跳出 循环 ， 执 行 后 面 的 语句 。 
while 循环 语句 的 流程 控制 图 如 图 4-17 所 示 。 


开始 
T 
一 | 程序 据 


图 4-17 while 语句 控制 流程 图 
【 例 4.13】 《实例 文件 :ch04\4.13.php) 
<?php 
Snum = 1; // 定 义 变量 Snum 
$str = "20 以 内 的 奇数 为 :"; ”// 定 义 变量 $x 
while ($num <=20){ // 判 断 Snum 是 否 小 于 或 等 于 20 
if(Snum % 2!= 0){ // 判 断 Snum 是 否 为 奇数 ， 为 奇数 则 输出 ， 否 则 做 加 一 操作 
$str .= $num." "7 
} 


$numt+; 
} 
echo $str; 
> 


运行 后 结果 如 图 4-18 所 示 。 





可 
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2 while 于 名 的 使 用 


文件 (F) 锭 总 (E) 查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 





20 以 内 的 奇数 为 , 1 3 5 7 9 11 13 15 17 19 


图 4-18 程序 运行 结果 
本 实例 主要 实现 20 以 内 的 奇数 输出 。 从 1~20 依次 判断 是 否 为 奇数 ， 如 果 是 ， 则 输出 ， 如 果 
不 是 ， 则 继续 下 一 次 的 循环 。 


4.6.2 ”do…while 循环 语句 


do…while 循环 的 结构 为 : 
dof 

命令 执行 语句 ; 
}while (条 件 判断 语句 ) 


其 中 先 执行 do 后 面 的 “命令 执行 语句 ”， 其 中 的 变量 会 随 着 命令 的 执行 发 生变 化 。 当 此 变量 
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通过 while 后 的 “条 件 判 断 语句 ”判断 为 false 时 ， 停 止 执行 “命令 执行 语句 ”。 
do…while 循环 语句 的 流程 控制 图 如 图 4-19 所 示 。 


开始 





程 











图 4-19 do…while 循环 语句 控制 流程 图 
【 例 4.14】 《实例 文件 ，ch04\4.14.php) 


<?php 

$aa = 0; // 声 明 一 个 整数 变量 $aa 

while($aa != 0){ // 使 用 while 循环 输出 
echo "不 会 被 执行 的 内 容 "; // 这 句 话 不 会 被 输出 

} 

do{ // 使 用 do…while 循环 输出 
echo "被 执行 的 内 容 "; // 这 句 话 会 被 输出 

}while($aa != 0); 

> 


运行 后 结果 如 图 4-20 所 示 。 从 结果 可 以 看 出 ，while 语句 和 do…while 语句 有 很 大 的 区 别 。 
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图 4-20 程序 运行 结果 


4.6.3 for 循环 语句 
for 循环 的 结构 为 : 


for (exprl; expr2; expr3) 
{ 


执行 命令 语句 
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其 中 exprl 为 条 件 的 初始 值 ，expr2 为 判断 的 最 终 值 ， 通 常 都 使 用 比较 表达 式 或 逻辑 表达 式 充 
当 判 断 的 条 件 ， 执 行 完 命令 语句 后 ， 再 执行 expr3。 


for 循环 语句 的 流程 控制 图 如 图 4-21 所 示 。 
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图 4-21 for 循环 语句 控制 流程 图 
【 例 4.15】 (实例 文件 ，ch04\4.15.php) 
<?php 


for($i=0;$i<4;$i++) { // 使 用 for 循环 输出 
echo "for 语句 的 功能 非常 强大 <br/>"; 


多 


运行 结果 如 图 4-22 所 示 。 从 图 中 可 以 看 出 ， 命 令 语句 执行 了 4 次。 


EEE 7EECURET 





句 的 功能 非常 强大 
的 功能 非常 强大 
9 功 训 避 











图 4-22 程序 运行 结果 
4.6.4 ”foreach 循环 语句 


foreach 语句 是 常用 的 一 种 循环 语句 ， 它 经 常 被 用 来 壳 历数 组 元 素 。 它 的 格式 为 : 
foreach (数组 as 数组 元 素 ) { 


对 数组 元 素 的 操作 命令 ; 
} 


可 以 根据 数组 的 情况 分 为 两 种 ， 即 不 包含 键 值 的 数组 和 包含 键 值 的 数组 。 
不 包含 键 值 的 : 


foreach (数组 as 数组 元 素 值 ){ 


对 数组 元 素 的 操作 命令 ; 
} 
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包含 键 值 的 : 


foreach (数组 as 键 值 => 数组 元 素 值 ) { 
对 数组 元 素 的 操作 命令 ; 
} 


每 进行 一 次 循环 ， 当 前 数组 元 素 的 值 就 会 被 赋值 给 数组 元 素 值 变 量 ， 数 组 指针 会 逐一 地 移动 ， 
直到 遍历 结束 为 止 。 
【 例 4.16】 《实例 文件 ，ch04\4.16.php) 


<?php 
$arr=array ("one", "two", "three"); 
foreach ($arr as $value) // 使 用 foreach 循环 输出 
1! 
echo "数组 值 : " . $value . "<br />"; 


We 


运行 结果 如 图 4-23 所 示 。 从 图 中 可 以 看 出 ， 命 令 语句 执行 了 3 次 。 
| _ 文 #D 需 澡 二 看 V) 相关 A) 工具 Tm a” 
部 组 值 : one i 


数组 值 : 
孝 组 信 : thre= 








本 100% ~ 


图 4-23 程序 运行 结果 
4.6.5 “流程 控制 的 另 一 种 书写 格式 


在 一 个 含有 多 条 件 、 多 循环 的 语句 中 ， 包 含 多 个 “{} ”， 查 看 起 来 比较 烦琐 。 流 程控 制 语 
言 的 另外 一 种 书写 方式 是 以 “: ”来 代替 左边 的 大 括号 , 使 用 endif; 、endwhile、endfor、 endforeach; 
和 endswitch; 来 替代 右边 的 大 括号 ， 这 种 描述 程序 结构 的 可 读 性 比较 强 。 常 见 的 格式 如 下 。 

条 件 控制 语句 中 的 论语 句 : 

if (条 件 判断 语句 ) : 
命令 执行 语句 ; 
elseif (条件 判断 语句 ) : 
命令 执行 语句 ; 
elseif (条 件 判 断 语句 ) : 
命令 执行 语句 ; 





else: 


命令 执行 语句 ; 
endif; 


条 件 控 制 语句 中 的 switch 语句 : 


循环 控制 语句 中 的 while 循环 : 


循环 控制 语句 中 的 do…while 循环 : 


循环 控制 语句 中 的 for 循环 ; 


【 例 4.17】 实例 文件 ，ch044.17.php) 











运行 结果 如 图 4-24 所 示 。 从 效果 图 可 以 看 出 ， 该 代码 使 用 新 的 书写 格式 实现 了 杨辉 三 角 的 排 
列 输出 。 


161521561 
172 中 85 史 71 

18 中 中 四 中 加 31 
19358412812% 24691 





图 4-24 程序 运行 结果 
4.6.6 使 用 break/continue 语句 跳出 循环 


使 用 break 关键 字 ， 用 来 跳出 〈 也 就 是 终止 ) 循环 控制 语句 和 条 件 控制 语句 中 的 switch 语句 的 
执行 。 例 如 : 
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在 这 段 程序 中 ，while 循环 控制 语句 里 面包 含 一 个 switch 流程 控制 语句 。 在 程序 执行 到 break 
语句 时 ，break 会 终止 执行 switch 语句 ,或 者 是 switch 和 while 语句 。 其 中 在 “case 1” 下 的 break 
语句 跳出 switch 语句 .case 2” 下 的 break 2 语句 跳出 switch 语句 和 包含 switch 的 while 语 句 。“case 3” 
下 的 break 1 语句 和 “case 1” 下 的 break 语句 一 样 ， 只 是 跳出 switch 语句 。 其 中 ，break 后 带 的 数 
字 参 数 是 指 break 要 跳出 的 控制 语句 结构 的 层 数 。 

使 用 continue 关键 字 的 作用 是 ， 跳 开 当 前 的 循环 迭代 项 ， 直 接 进 入 到 下 一 个 循环 迭代 项 ， 继 
续 执 行程 序 。 下 面 通过 一 个 实例 说 明 此 关键 字 作 用 。 

【 例 4.18】《〔 实 例文 件 ，ch04\4.18.php) 

<?php 

Sn = 0; 

while (Sn++ < 6) {  // 使 用 while 循环 输出 

if ($n == 2){ 
continue; 








} 
echo $n."<br />"; 
} 


?> 


运行 结果 如 图 4-25 所 示 。 








ET 








图 4-25 程序 运行 结果 
其 中 continue 关键 字 ， 在 当 n 等 于 2 的 时 候 ， 跳 出 本 次 循环 ， 并 且 直 接 进 入 到 下 一 个 循环 迭 
代 项 ， 即 当 n 等 于 3。 另 外 ，continue 关键 字 和 break 关键 字 一 样 ， 都 可 以 在 后 面 直 接 跟 一 个 数字 
参数 ， 用 来 表示 跳 开 循环 的 结构 层 数 。“continue” 和 “continue 1” 相 同 ，“continue 2” 表 示 跳 开 
所 在 循环 和 上 一 级 循环 的 当前 迭代 项 。 


4.7 ”实战 演练 1 一 一 条 件 分 支 结 构 综 合 应 用 


下 面 ， 通 过 案例 讲述 条 件 分 支 结构 的 综合 应 用 。 
【 例 4.19】 《实例 文件 :ch04\4.19.php) 
<?php 
$members = Null; 
function checkmembers ($members){ 
if ($members < 1){ 
echo "我 们 不 能 为 少 于 一 人 的 顾客 提供 房间 。<br />"; 
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}else{ 
echo "欢迎 来 到 GoodHome 酒店 。<br />"; 
} 
} 
checkmembers (2); 
checkmembers (0.5); 
function checkmembersforroom($members){ 
if ($members < 1){ 
echo "我 们 不 能 为 少 于 一 人 的 顾客 提供 房间 。<br />"; 
}elseif( $members == 1 ){ 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 单 床 房 。<br />"; 
}elseif( $members == 2 ){ 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 标准 间 。<br />"; 
}elseif( $members == 3 ){ 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 三 床 房 。<br />"; 
}elsel{ 
echo "请 直接 电话 联系 我 们 ， 我 们 将 依照 具体 情况 为 您 准备 合适 的 房间 。<br />"; 
} 
1 
checkmembersforroom(1) 7 
checkmembersforroom(2) 7 
checkmembersforroom(3) 
checkmembersforroom(5) 7 
function switchrooms ($members){ 
switch ($members){ 
case 1; 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 单 床 房 。<br />"; 
break; 
case 2; 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 标准 间 。<br />"; 
break; 
case 3; 
echo "欢迎 来 到 GoodHome 酒店 。 我 们 将 为 您 准备 三 床 房 。<br />"; 
break; 
default: 
echo "请 直接 电话 联系 我 们 ， 我 们 将 依照 具体 情况 为 您 准备 合适 的 房间 。"; 
break; 
下 
上 
Switchrooms (1) 7 
Switchrooms (2) 
Switchrooms (3) 7 
Switchrooms (5) 7 
2 


运行 结果 如 图 4-26 所 示 。 
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图 4-26 程序 运行 结果 
其 中 最 后 4 行 由 switch 语句 实现 。 其 他 输出 均 由 让 语句 实现 。 
4.8 实战 演练 2 一 一 循环 控制 结构 综合 应 用 


下 面 以 遍历 已 订房 间 门 牌号 为 例 介绍 循环 控制 语句 的 应 用 技巧 。 
【 例 4.20】“〈 实 例文 件 ，ch04\4.20.php) 


<?php 
$bookedrooms =array ('102','202','203','303','307');  // 定 义 数组 bookedrooms 
Or NS 0 3 5 SEE // 循 环 输出 数组 bookedrooms 
echo Sbookedrooms [$i]."<br />"; 
} 


function checkbookedroom while($bookedrooms) { // 定 义 函数 
$i = 0; 
while (isset ($bookedrooms [$i])){ 
echo $i.":".$bookedrooms[$i]."<br />"; 
放下 HH 
} 


} 
checkbookedroom while($bookedrooms); 


$i = 0; 
dol{ 
echo $i."-".$bookedrooms[$i]."<br />"; 
$i++;? 
}while ($i < 2); 
> 


运行 结果 如 图 4-27 所 示 。 
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图 4-27 程序 运行 结果 
其 中 , 102~307 由 for 循环 实现 。 0: 102~4: 307 由 while 循环 实现 。0-102 和 1-202 由 do…while 
循环 实现 。for 循环 和 while 循环 都 完全 遍历 了 数组 Sbookedrooms， 而 do…while 循环 由 于 while ($i 
<2) ， 所 以 do 后 面 的 命令 执行 了 两 次 。 


4.9 高 手 私 房 菜 


技巧 1: 如 何 合理 运用 include_once() 和 require_once()? 
答 : include() 和 require() 函 数 在 其 他 PHP 语句 执行 之 前 运行 ， 引 入 需要 的 语句 并 加 以 执行 。 但 
是 每 次 运行 包含 此 语句 的 PHP 文件 时 , include() 和 require0 函 数 都 要 运行 一 次 。include() 和 require() 
函数 如 果 在 先前 已 经 运行 过 , 并 且 引 入 相同 的 文件 , 则 系统 就 会 重复 引入 这 个 文件 , 从 而 产生 错误 。 
而 include_once() 和 require_once() 函 数 只 是 在 此 次 运行 的 过 程 中 引入 特定 的 文件 或 代码 ， 但 是 在 引 
入 之 前 , 会 先 检查 所 需 文件 或 者 代码 是 否 已 经 引入 , 如 果 引 入 将 不 再 重复 引入 , 从 而 不 会 造成 冲突 。 
技巧 2: 程序 检查 后 正确 ， 却 显示 Notice: Undefined variable， 为 什么 ? 
PHP 默认 配置 会 报 这 个 错误 ， 这 就 是 警告 将 在 页 面 上 打印 出 来 ， 虽 然 这 有 利于 暴露 问题 ， 但 
现实 使 用 中 会 存在 很 多 问题 。 通 用 解决 办 法 是 修改 php.ini 的 配置 ， 需 要 修改 的 参数 如 下 : 
(1) 找到 error reporting =E_ALL 
修改 为 error reporting=E_ ALL& ~E NOTICE 
(2) 找到 register_globals = Off 
修改 为 register_globals = On 


4.10 经 典 习 题 


(1) 制作 一 个 包含 内 置 函 数 的 例子 ， 随 机 输出 10~99 之 间 的 整数 。 
(2) 制作 一 个 包含 自 定义 函数 的 例子 ， 包 含 向 函数 传递 参数 引用 。 
(3) 制作 一 个 包含 文件 引用 的 例子 。 

(4) 制作 一 个 包含 条 件 分 支 结构 的 例子 。 

(5) 制作 一 个 包含 循环 控制 结构 的 例子 。 


第 5 章 字符 串 和 正则 表达 式 


字符 串 在 PHP 程序 中 经 常 被 使 用 ， 那 么 如 何 格式 化 字符 串 、 如 何 连接 分 离 字 符 串 、 如 何 比 较 
字符 串 等 ， 是 初学 者 经 常 遇 到 的 问题 。 另 外 ， 本 章 还 将 讲述 正则 表达 式 的 使 用 方法 和 技巧 。 
本 章 学 习 目标 
掌握 字符 串 单 引 号 和 双 引 号 的 使 用 
掌握 字符 串 连接 符 的 使 用 
掌握 字符 串 的 基本 操作 
熟悉 正则 表达 式 的 基本 概念 
掌握 正则 表达 式 的 语法 规则 


5.1 字符 串 的 单 引 号 和 双 引 号 


字符 串 是 指 一 连 串 不 中 断 的 字符 。 这 里 的 字符 主要 包括 以 下 几 种 类 型 
字母 类 型 ， 如 常见 的 a、b、c 等 。 
数字 类 型 ， 如 常见 的 1、2、3、4 等 。 
特殊 字符 类 型 ， 如 常见 的 #、%、^、$ 等 。 
不 可 见 字符 类 型 ， 如 回 车 符 、Tab 字符 和 换行 符 等 。 
标识 字符 串通 常 使 用 单 引 号 或 双 引 号 ， 表 面 看 起 来 没有 什么 区 别 。 但 是 ， 对 于 存在 于 字符 串 
中 的 变量 ， 这 两 个 是 不 一 样 的 。 
(1) 双 引 号 内 会 输出 变量 的 值 。 单 引号 内 直接 显示 变量 名 称 。 
(2) 双 引 号 中 可 以 通过 “\” 转 义 符 输 出 的 特殊 字符 如 下 。 


nz 


地 
N 


\0: 
\$: 
NT: 


新 一 行 。 

TAB。 

反 儿 杠 。 

ASCI 码 的 0。 

把 此 符号 转 义 为 单纯 的 美元 符号 ， 而 不 再 作为 声明 变量 的 标识 符 。 
回 车 


\{octal #}: 八进制 转 义 。 
\x{hexadecimal#}: 十 六 进 制 转 义 。 


另外 ， 单 引号 中 可 以 通过 “\” 转 义 符 输出 的 特殊 字符 只 有 : 


Ns 
人 


转 义 为 单 引号 本 身 ， 而 不 作为 字符 串 标识 符 。 
用 于 在 单 引号 前 的 反 儿 杠 转 义 为 其 本 身 。 
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下 面 通过 实例 来 讲解 它们 的 不 同 用 法 。 
【 例 5.1】《〈 实 例文 件 : ch05\5.1.php) 


<?php 


$message = "PHP 程序 "; // 定 义 字 符 串 变量 

echo "这 是 关于 字符 串 的 程序 。<br />"; // 输 出 字符 串 变量 

echo "这 是 一 个 关于 双 引 号 和 \$ 的 $message<br />";  ”// 使 用 转 义 字符 
$message2 = ' 字 符 串 的 程序 。' 7 // 使 用 单 引 号 赋值 字符 串 变量 
echo ' 这 是 一 个 关于 字符 串 的 程序 。<br /> "7 // 输 出 字符 串 变量 


echo ' 这 是 一 个 关于 单 引 号 的 $message2'; 
echo $message2; 
Se 
运行 结果 如 图 5-1 所 示 。 可 见 单 引号 串 和 双 引 号 串 在 PHP 的 中 处 理 普 通 的 字符 串 时 效果 是 一 
样 的 , 而 在 处 理 变 量 时 是 不 一 样 的 , 单 引号 串 中 的 内 容 只 是 被 当成 普通 的 字符 串 处 理 , 而 双 引 号 串 
的 内 容 是 可 以 被 解释 并 蔡 换 的 。 
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这 是 关于 字符 串 的 程序 。 

这 是 一 个 关于 双 引号 和 $ 的 PHP 程 序 

这 是 一 个 关于 字符 串 的 程序 。 

这 是 一 个 关于 单 引号 的 $message2 字 符 串 的 程序 。 




















图 5-1 程序 运行 结果 


【案例 分 析 】: 

(1) 其 中 ， 第 一 段 程序 使 用 双 引 号 对 字符 串 进 行 处 理 ，“\$” 转 义 成 了 美元 符号 ，$message 
的 值 "PHP 程序 "被 输出 。 

(2) 第 二 段 程序 使 用 单 引号 对 字符 串 进行 处 理 。$message2 的 值 在 单 引 号 的 字符 串 中 无 法 被 
输出 ， 但 是 可 以 通过 变量 被 直接 打印 出 来 。 


5.2 ”字符 串 的 连接 符 


字符 串 连 接 符 的 使 用 十 分 常见 。 这 个 连接 符 就 是 “.” (点) ， 它 可 以 直接 连接 两 个 字符 串 ， 
可 以 连接 两 个 字符 串 变 量 ， 也 可 以 连接 字符 串 和 字符 串 变 量 ， 如 下 面 的 实例 所 示 。 
【 例 5.2】〔 实 例文 件 ，ch05\5.2.php) 
<?php 
// 定 义 字 符 串 
$a =" 使 用 字符 串 的 连接 符 "; 





















































运行 结果 如 图 5-2 所 示 。 


Geeewecreea-acxlscw 
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使 用 字符 串 的 连接 符 ， 可 以 非 党 方面 地 庄 接 字符 率 





图 5-2 程序 运行 结果 


除了 上 面 的 方法 以 外 ， 读 者 还 可 以 使 用 {} 的 方法 连接 字符 串 ， 此 方法 类 似 于 C 语言 中 printf 
的 占 位 符 。 下 面 举例 说 明 其 使 用 方法 。 
【 例 53】《〈 实 例文 件 ， ch05\5.3.php) 


运行 结果 如 图 5-3 所 示 。 








5-3 ”程序 运行 结果 
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5.3 ”字符 串 的 基本 操作 


字符 串 的 基本 操作 主要 包括 对 字符 串 的 格式 化 处 理 、 连 接 切 分 字符 串 、 查 找 字符 串 、 替 换 字 


5.3.1 手动 和 自动 转 义 字符 串 中 的 字符 


手动 转 义 字符 串 数据 ， 就 是 在 引号 内 包括 单 引号 和 双 引 号 ) 通过 “\” 反 斜 杠 使 一 些 特殊 字 
符 转 义 为 普通 字符 。 在 介绍 单 引号 和 双 引 号 的 时 候 已 经 对 这 个 方法 进行 了 详细 的 描述 。 

自动 转 义 字 符 串 的 字符 ， 是 通过 PHP 的 内 置 函 数 addslashes() 来 完成 的 。 还 原 这 个 操作 则 是 通 
过 stripslashes() 来 完成 的 。 以 上 两 个 函数 ， 也 经 常 使 用 在 格式 化 字符 串 中 以 用 于 MySQL 的 数据 库 
存储 。 


5.3.2 ”计算 字符 串 的 长 度 


计算 字符 串 的 长 度 经 常 在 很 多 应 用 中 出 现 ， 比 如 输入 框 输入 文字 的 长 度 等 ， 都 会 用 到 此 功能 。 
使 用 strlen0 函 数 就 可 以 实现 这 个 功能 。 以 下 实例 介绍 计算 字符 串 长 度 的 方法 和 技巧 。 
【 例 5.4】〔 实 例文 件 ，ch05\5.4.php) 





<?php 
$someinput = "这 个 字符 申 的 长 度 不 长 。length is not long."; // 定 义 字 符 串 变量 
$length = strlen($someinput); // 获 取 字 符 串 变量 的 长 度 


if(strlen($someinput)>50){ 
echo "输入 的 字符 串 的 长 度 不 能 大 于 50 个 字符 。"; 
}else{ 


echo "允许 输入 字符 串 的 长 度 ， 此 字符 串 长 度 为 $length"; 
2 


运行 结果 如 图 54 所 示 。 
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允许 输入 字符 串 的 长 度 ， 此 字符 串 长 度 为 虹 








图 5-4 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 $someinput 为 一 个 字符 串 变 量 。strlen($someinpub 则 直接 调用 strlen() 函 数 计算 出 字 
符 串 的 长 度 。 

(2) 在 让 语句 中 strlen($someinput) 返 回 字符 串 长 度 并 与 50 这 一 上 限 作 比较 。 由 于 $someinput 
中 有 中 文 和 英文 两 种 字符 ， 它 的 长 度 为 41， 正 如 输出 所 示 。 
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(3) 由 于 每 个 中 文字 占 两 个 字符 位 ， 每 个 英文 字符 占 一 个 字符 位 ， 字 符 串 内 的 每 个 空格 也 算 
一 个 字符 位 ， 所 以 ， 最 后 字符 串 的 长 度 为 41 个 字符 。 
5.3.3 字符 串 单词 统计 

有 时 对 字符 串 的 单词 进行 统计 有 更 大 意义 。 使 用 str_word_count() 函 数 可 以 实现 此 操作 ， 但 是 
这 个 函数 只 对 基于 ASCII 码 的 英文 单词 起 作用 ， 并 不 对 UTF8 的 中 文字 符 起 作用 。 

下 面 通过 实例 介绍 字符 串 单词 统计 中 的 应 用 和 技巧 。 

【 例 5.5】〔 实 例文 件 : ch05\7.php) 


<?php 
$someinput = "How many words in this sentance? Just count it."; 0 
字符 串 变量 
$someinput2 = "这 个 句子 由 多 少 个 汉字 组 成 ? 数 一 数 也 不 知道 。" 
echo str word count ($someinput)."<br />"; // 计 算 单 词 个 数 
echo str_word_count ($someinput2); 
> 


运行 结果 如 图 5-5 所 示 。 可 见 str_word_count() 函 数 无 法 计算 中 文字 符 ， 查 询 结 果 为 0。 
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图 5-5 程序 运行 结果 
5.3.4 ”清理 字符 串 中 的 空格 

空格 在 很 多 情况 下 是 不 必要 的 ， 所 以 清除 字符 串 中 的 空格 显得 十 分 重要 。 比 如 在 判定 输入 是 
否 正确 的 程序 中 ， 出 现 了 不 必要 的 空格 ， 将 增 大 程序 出 现 错误 判断 的 机 率 。 

清除 空格 要 用 到 ltrim()、rtrim0 和 trim0 函 数 。 其 中 ltim0 是 从 左面 清除 字符 串 头 部 的 空格 。 
rtrim0 是 从 右面 清除 字符 串 尾部 的 空格 。trim0 则 是 从 字符 串 两 边 同 时 去 除 头 部 和 尾部 的 空格 。 

以 下 实例 介绍 去 除 字 符 串 中 空格 的 方法 和 技巧 。 

【 例 5.6】〔 实 例文 件 ，ch05\5.6.php) 


<?php 
$someinput = "这 个 字符 串 的 空格 有 待 处 理 。 "; // 定 义 字符 串 变量 
echo "Output:".1trim(Ssomeinput) ."End <br />"; // 清 理 字 符 串 头 部 的 空格 
echo "Output:" .rtrim(Ssomeinput) ."End <br />"; // 清 理 字符 串 头 部 尾部 的 空格 
echo "Output:".trim($someinput)."End <br />"; // 同 时 去 除 头 部 和 尾部 的 空格 


$someinput2 = ”这 个 字符 串 的 空格 有 待 处 理 。"; // 定 义 中 间 有 空格 的 字符 串 变量 
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echo "Output:".trim($someinput2) ."End"; // 同 时 去 除 头 部 和 尾部 的 空格 


2 


运行 结果 如 图 5-6 所 示 。 





【案例 分 析 】: 


(1) 其 中 , $someinput 为 一 个 两 端 都 有 空格 的 字符 串 变 量 。ltrim($someinput) 从 左边 去 除 空格 ， 
rtrim($someinput) 从 右面 去 除 空格 ，trim($someinput) 从 两 边 同 时 去 除 ， 得 到 输出 如 图 5-6 所 示 。 

(2) 其 中 $someinput2 为 一 个 两 端 都 有 空格 ， 并 且 中 间 也 有 空格 的 字符 串 变 量 。 用 
trim($someinput2) 处 理 ， 但 还 只 是 去 除 两 边 的 空格 。 


5.3.5 “字符 串 的 切 分 与 组 合 


字符 串 的 切 分 使 用 explode0 和 strtok0 函 数 。 切 分 的 反 向 操作 为 组 合 ， 使 用 implode0 和 join() 
函数 。 其 中 explode() 把 字符 串 切 分 成 不 同 部 分 后 ， 存 入 一 个 数组 。Impolde0 函 数 则 是 把 数组 中 的 
元 素 按 照 一 定 的 间隔 标准 组 合成 一 个 字符 串 。 
以 下 实例 介绍 去 除 字符 串 切 分 和 组 合 的 方法 和 技巧 。 
【 例 5.7】 实 例文 件 : ch05\5.7.php) 
<?php 
$someinput = "How to split this sentance."; // 定 义 字符 串 变量 
$someinput2 = "把 这 个 句子 按 空 格 拆 分 。"; // 定 义 按 空 格 拆 分 的 字符 串 
$a = explode('_',$someinput); // 切 分 字符 串 someinput 
print r($a); // 输 出 切 分 后 的 字符 串 
$b = explode(' ',$someinput2); 
print _r($b); 
echo implode('>',$a)."<br />"; // 组 合 字符 串 $a 
echo implode('*',$b); 
Kee 


运行 结果 如 图 5-7 所 示 。 
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图 5-7 程序 运行 结果 
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【案例 分 析 】 : 


(1) 其 中 explode() 函 数 把 Ssomeinput 和 $someinput2 按照 下 划 线 和 空格 的 位 置 把 它们 分 别 切 
分 成 $a 和 $b 两 个 数组 。 

(2) 其 中 implode0 函 数 把 $a 和 $b 两 个 数组 的 元 素 分 别 按照 “>” 和 “*” 为 间隔 组 合成 新 的 
字符 串 。 


5.3.6 ”字符 串 子 串 的 截取 


在 一 个 字符 串 中 截取 一 个 子 串 ， 就 是 字符 串 截取 。 

完成 这 个 操作 需要 用 到 substr0) 函 数 。 这 个 函数 有 3 个 参数 ， 分 别 规定 了 目标 字符 串 、 起 始 位 
置 和 截取 长 度 。 它 的 格式 如 下 : 

substr (目标 字符 串 ， 起 始 位 置 ， 截 取 长 度 ) 


其 中 目标 字符 串 是 某 个 字符 串 变 量 的 变量 名 ， 起 始 位 置 和 截取 长 度 都 是 整数 。 

如 果 都 是 正 数 ， 起 始 位 置 的 整数 必须 小 于 截取 长 度 的 整数 ， 否 则 函数 返回 值 为 假 。 

如 果 截 取 长 度 为 负数 ， 则 意味 着 ， 是 从 起 始 位 置 开始 往 后 除去 从 目标 字符 串 结尾 算 起 的 长 度 

数 的 字符 以 外 的 所 有 字符 。 
以 下 实例 介绍 去 除 字符 串 截 取 的 方法 和 技巧 。 
【 例 5.8】 (实例 文件 ,ch05\5.8.php) 

<?php 
$someinput = "create a substring of this string.";  // 定 义 字 符 申 变量 $someinput 
$someinput2 = "创建 一 个 这 个 字符 串 的 子 串 。"; 


echo substr($someinput,0,11)."<br />"; // 截 取 字 符 串 前 11 个 字符 

echo substr($someinput,1,15)."<br />"; // 截 取 从 第 二 个 字符 开始 的 前 15 个 字 
符 

echo substr($someinput,0,-2)."<br />"; // 截 取 除 最 右 侧 两 个 字符 外 的 字符 

echo substr ($someinput2,0,12) ."<br />"; // 截 取 字 符 串 前 12 个 字符 

echo substr($someinput2,0,10)."<br />"; // 截 取 字 符 串 前 10 个 字符 

echo substr($someinput2,0,11); // 截 取 字 符 串 前 11 个 字符 

ys 


运行 结果 如 图 5-8 所 示 。 
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图 5-8 程序 运行 结果 
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【案例 分 析 】 : 


(1) 其 中 $someinput 为 英文 字符 串 变 量 。substr($someinput,0,11) 和 substr($someinput,1,15) 展 
示 了 起 始 位 和 截取 长 度 。substr($someinput,0,-2) 则 是 从 字符 串 开 头 算 起 ， 除 了 最 后 两 个 字符 ， 其 他 
字符 都 截取 的 子 字符 串 。 

(2) 其 中 $someinput2 为 中 文字 符 串 变 量 。 因 为 中 文字 符 是 全 角 字 符 ， 都 占 两 个 字符 位 ， 所 以 
截取 长 度 一 定 要 是 偶数 。 如 果 是 单数 则 在 此 字符 位 上 的 汉字 将 不 被 输出 。 如 果 在 这 样 截取 长 度 为 单 
数 的 字符 串 子 串 后 连接 其 他 字符 串 输出 ， 会 出 现 输出 错误 。 所 以 ， 要 小 心 使 用 。 


5.3.7 ”字符 串 子 串 替 换 


在 某 个 字符 串 中 替换 其 中 的 某 个 部 分 是 重要 的 应 用 ， 就 像 在 使 用 文本 编辑 器 中 的 替换 功能 一 
样 。 
完成 这 个 操作 需要 使 用 substr_replace() 函 数 ， 它 的 格式 为 : 
substr_replace (目标 字符 串 ， 蔡 换 字符 串 ， 起 始 位 置 ， 替 换 长 度 ) 
以 下 实例 介绍 字符 串 替换 的 方法 和 技巧 。 
【 例 5.9】〈 实 例文 件 : ch05\5.9.php) 


<?php 
$someinput = "ID:125846843388648"; // 定 义 字符 串 变量 
echo substr_replace($Ssomeinput，"*x**xxxxxxxxxxnr3r11) ."<br />"; // 字 符 串 字 串 
蔡 换 
echo substr _replace($someinput," 尾 号 为 ", 3,11); // 输 出 替换 后 的 字符 串 
> 


运行 结果 如 图 5-9 所 示 。 
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图 5-9 程序 运行 结果 





【案例 分 析 】: 
(1) 其 中 ，S$someinput 为 英文 字符 串 变量 。 从 第 三 个 字符 开始 为 ID 号 。 第 一 个 输出 是 以 
pptss##” 替换 第 三 个 字符 开始 往 后 的 11 个 字符 。 
(2) 第 二 个 输出 是 用 “ 尾 号 为 ”替代 第 三 个 字符 开始 往 后 的 11 个 字符 。 
5.3.8 字符 串 查找 


在 一 个 字符 串 中 查找 另外 一 个 字符 串 ， 就 像 文本 编辑 器 中 的 查找 一 样 。 实 现 这 个 操作 需要 用 
到 strstr() 或 stristr() 函 数 。 其 格式 为 : 
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strstr【〔〈 目 标 字 符 串 ， 需 查找 字符 串 ) 

如 果 函 数 找到 需要 查找 的 字符 或 字符 串 ， 则 返回 从 第 一 个 查找 到 字符 串 的 位 置 往 后 所 有 的 字 
符 串 内 容 。 

stristr() 函 数 为 不 敏感 查找 ， 也 就 是 对 字符 的 大 小 写 不 敏感 。 用 法 与 strstr0) 相 同 。 

以 下 实例 介绍 字符 串 查找 的 方法 和 技巧 。 

【 例 5.10】〔 实 例文 件 ，ch05\5.10.php) 


<?php 
$someinput = "I have a Dream that to find a string with a dream."; // 定 义 英 
文字 符 串 
$someinput2 = "我 有 一 个 梦想 ， 能 够 找到 理想 。" 7 /定义 中 文字 符 串 
echo strstr($someinput, "dream") ."<br />"; /查找 指定 的 字符 


echo stristr(S$someinput,"dream") ."<br />"; 

echo strstr($someinput,"that")."<br />"; 

echo strstr($someinput2, "梦想 ") ."<br />"; 
?> 


运行 结果 如 图 5-10 所 示 。 
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dream. 
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find a string with a dream. 
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图 5-10 程序 运行 结果 
【案例 分 析 】: 
(1) 其 中 $someinput 为 英文 字符 串 变量 。strstr($someinput,"dream") 大 小 写 敏感 ， 所 以 输出 字 
符 串 最 后 的 字符 。stristr($someinput,"dream'") 大 小 写 不 敏感 ， 所 以 直接 在 第 一 个 大 写 的 匹配 字符 就 
开始 输出 。 
(2) 其 中 $someinput2 为 中 文字 符 串 变量 。strstr0 函 数 同样 对 中 文字 符 起 作用 。 


5.3.9 ”大 小 写 转换 


在 PHP 中 ， 通 过 使 用 大 小 写 转换 函数 ， 可 以 修改 字符 串 中 字母 大 小 不 规范 的 问题 。 常 见 的 大 
小 写 转换 函数 如 下 : 


srting strtolower (srting str) ; // 转 换 为 小 写 
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srting strtoupper (srting str) ; // 转 换 为 大 写 
srting ucfirst (srting str); // 整 个 字符 串 首 字母 大 写 
srting ucwords (srting str) ;  // 整 个 字符 串 中 以 空格 为 分 隔 符 的 单词 首 字 母 大 写 


【 例 5.11】 《实例 文件 :ch05\5.11.php) 


<?php 

$str = "hello I have a dream" ; /定义 英文 字符 串 

echo strtolower ($str) ."<br />"; // 转 换 为 小 写 

echo strtoupper ($str)."<br />"; // 转 换 为 大 写 

echo ucfirst ($str)."<br />"; // 整 个 字符 串 首 字母 大 写 

echo ucwords (Sstr) ."<br />"; // 整 个 字符 串 中 以 空格 为 分 隔 符 的 单词 首 字母 大 写 
echo $aa; // 输 出 原 字符 串 

>: 


运行 结果 如 图 5-11 所 示 。 
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图 5-11 程序 运行 结果 


5.4 ”什么 是 正则 表达 式 


上 面 介绍 的 对 字符 串 的 处 理 方法 比较 简单 ， 只 是 使 用 一 定 的 函数 对 字符 串 进 行 处 理 ， 无 法 满 
足 对 字符 串 的 复杂 处 理 需求 ， 此 时 就 需要 使 用 正则 表达 式 。 

正则 表达 式 是 把 文本 或 字符 串 按照 一 定 的 规范 或 模型 表示 的 方法 ， 经 常用 于 文本 的 匹配 操作 。 

例如 ， 验 证 用 户 在 线 输入 的 邮件 地 址 的 格式 是 否 正确 。 常 常 使 用 正则 表达 式 技术 ， 用 户 所 填 
写 的 表单 信息 将 会 被 正常 处 理 ; 反之 ， 如果 用 户 输入 的 邮件 地 址 与 正则 表达 的 模式 不 匹配 , 将 会 弹 
出 提示 信息 ， 要 求 用 户 重新 输入 正确 的 邮件 地 址 。 可 见 正则 表达 式 在 Web 应 用 的 罗 辑 判断 中 具有 
举足轻重 的 作用 。 





5.5 ”正则 表达 式 语法 规则 
一 般 情况 下 ， 正 则 表达 式 由 两 部 分 组 成 ， 分 别 是 元 字符 和 文本 字符 。 元 字符 就 是 具有 特殊 合 


义 的 字符 ， 例 如 “? ”和 “*” 等 ， 文 本 字符 就 是 普通 的 文本 ， 例 如 字母 和 数字 等 。 本 节 主 要 讲述 
正则 表达 式 的 语法 规则 。 
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1. 方 括号 〈[]) 


方 括号 内 的 一 串 字 符 是 将 要 用 来 进行 匹配 的 字符 .例如 正则 表达 式 在 方 括号 内 的 [name] 是 指 在 
目标 字符 串 中 寻找 字母 n、a、m、e。[ijk] 表 示 在 目标 字符 串 中 寻找 字符 j] 和 kk。 

2. 连 字符 (-) 

在 很 多 情况 下 ， 不 可 能 逐个 列 出 所 有 字符 。 比 如 ， 若 要 匹配 所 有 英文 字符 ， 则 把 26 个 英文 字 
母 全 部 输入 会 十 分 困难 。 这 样 就 有 如 下 表示 : 

@ 。 [a-z] 表 示 匹 配 英文 小 写 从 a 到 z 的 任意 字符 。 

@ [A-Z] 表 示 匹 配 英文 大 写 从 A 到 的 任意 字符 。 

@ [A-Za-z] 表示 匹配 英文 大 小 写 从 大 写 A 到 小 写 z 的 任意 字符 。 

@ [0-9] 表 示 匹 配 从 0 到 9 的 任意 十 进 制 数 。 


由 于 字母 和 数字 的 区 间 固 定 ， 所 以 根据 这 样 的 表示 方法 ， 即 [开始 -结束 ]， 程 序 员 可 以 重新 定 
义 区 间 大 小 ， 如 [2-7]、[c- 有 等 。 


3. 点 号 字符 (.) 


点 号 字符 在 正则 表达 式 中 是 一 个 通配符 ， 它 代表 所 有 字符 和 数字 ， 例 如 ，“.er” 表 示 所 有 以 
er 结尾 的 三 个 字符 的 字符 串 ， 可 以 是 per、ser、ter、@er、&er 等 。 

4. 限定 符 (+*? {n,m}) 

加 号 “+” 表示 其 前 面 的 字符 至 少 有 一 个 。 例 如 ，“9+” 表 示 目 标 字 符 串 包含 至 少 一 个 9。 

星 号 “*” 表 示 其 前 面 的 字符 不 止 一 个 或 零 。 例 如 ，“y*” 表 示 目 标 字符 串 包含 0 或 不 止 一 个 y。 

问号 “? ”表示 其 前 面 的 字符 为 一 个 或 零 。 例 如 ，“y? ”表示 目标 字符 串 包含 0 或 一 个 y。 

大 括号 “ {n,m}” 表 示 其 前 面 的 字符 有 n 或 m 个 。 例 如 ，“a{3，5}” 表 示 目 标 字符 串 包含 3 
个 或 5 个 a。“a{3}” 表 示 目 标 字 符 串 包含 3 个 a。“a{3，}” 表 示 目 标 字 符 串 包含 至 少 3 个 a。 

点 号 和 星 号 可 以 一 起 使 用 ， 如 “.*” 表 示 匹 配 任意 字符 。 

5. 行 定位 符 (^ 和 $) 

行 定位 符 用 来 确定 匹配 字符 串 所 要 出 现 的 位 置 。 

如 果 是 在 目标 字符 串 开头 出 现 ， 则 使 用 符号 “^”; 如 果 是 在 目标 字符 串 结尾 出 现 ， 则 使 用 符 
号 “$”。 例 如 ，^xiaoming 是 指 xiaoming 只 能 出 现在 目标 字符 串 开 头 。8895$ 是 指 8895 只 能 出 现 
在 目标 字符 串 结 尾 。 

同时 使 用 “^$” 这 两 个 符号 ， 如 “^[a-z]$”， 表 示 目 标 字符 串 要 只 包含 从 a 到 z 的 单个 字符 。 


6. 排除 字符 〈 闪 ) 

符号 “^” 在 方 括号 内 所 代表 的 意义 则 完全 不 同 ， 它 表示 一 个 逻辑 “和 否 ”。 排 除 匹 配 字符 串 在 
目标 字符 串 中 出 现 的 可 能 ， 例 如 [^0-9] 表 示 目 标 字符 串 包含 从 0 到 9“ 以 外 ”的 任意 其 他 字符 。 

7. 括号 字符 〈()) 


括号 字符 表示 子 串 ， 所 有 对 包含 在 子 串 内 字符 的 操作 ， 都 是 以 子 串 为 整体 进行 的 。 括 号 字符 
也 是 把 正则 表达 式 分 成 不 同 部 分 的 操作 符 。 
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8. 选择 字符 (|) 

选择 字符 表示 “或 ”选择 。 例如 ,“comlcnlcom.cnlnet” 表 示 目 标 字 符 串 包含 com 或 cn 或 com.cn 
或 net。 

9. 转 义 字符 (\) 与 反 斜 线 (\) 

由 于 “\” 在 正则 表达 式 中 属于 特殊 字符 ， 如 果 单独 使 用 此 字符 ， 则 直接 表示 为 作为 特殊 字符 
的 转 义 字符 。 如 果 要 表示 反 斜 杠 字符 本 身 ， 则 在 此 字符 前 添加 转 义 字 符 “\”， 即 “\N”。 

10. 认证 email 的 正则 表达 

在 处 理 表 单数 据 的 时 候 ， 对 用 户 的 email 进行 认证 是 十 分 常用 的 。 如 何 判断 用 户 输入 的 是 一 个 
email 地 址 呢 ? 就 是 用 正则 表达 式 匹配 。 它 的 格式 如 下 。 

[a Za=z0=90 + A Za=20=90]7N [a Za z0=901% 

其 中 ^[A-Za-z0-9_.]+ 表 示 ， 至 少 有 一 个 英文 大 小 写字 符 、 数 字 、 下 划 线 、 点 号 ,或 者 这 些 字符 
的 组 合 。@ 表 示 email 中 的 “@”。[ A-Za-z0-9_]+ 表 示 ， 至 少 有 一 个 英文 大 小 写字 符 、 数 字 、 下 划 
线 ， 或 者 这 些 字符 的 组 合 。\. 表 示 email 中 “.com” 之 类 的 点 。 由 于 这 里 点 号 只 是 点 本 身 ， 所 以 用 
反 斜 本 对 它 进行 转 义 。[ A-Za-z0-9.]+$ 表 示 ， 至 少 有 一 个 英文 大 小 写字 符 、 数 字 、 点 号 ， 或 者 这 些 
字符 的 组 合 ， 并 且 直 到 这 个 字符 串 的 末尾 。 

11. 如 何 使 用 正则 表达 式 对 字符 串 进行 匹配 

使 用 正则 表达 式 对 目标 字符 串 进行 匹配 是 正则 表达 式 的 主要 功能 。 

完成 这 个 操作 需要 用 到 ereg() 函 数 。 这 个 函数 用 于 在 目标 字符 串 中 寻找 符合 特定 正则 表达 规范 
的 字符 串 子 串 ， 根 据 指 定 的 模式 来 匹配 文件 名 或 字符 串 。 其 中 ereg0) 函 数 对 字符 大 小 写 不 敏感 。 它 
的 语法 格式 如 下 : 

ereg《〔〈 正 则 表达 规范 ， 目 标 字 符 串 ， 数 组 ) 

提示 : 另外 用 户 也 可 以 使 用 eregiO 函 数 对 字符 串 进行 匹配 ， 它 和 ereg0) 函 数 最 大 区 别 是 对 字符 
大 小 写 敏感 。 

下 面 介绍 利用 正则 表达 规范 匹配 email 输入 的 方法 和 技巧 。 

【 例 5.12】 《实例 文件 :ch05\5.12.php) 


<?php 
Semail = "wangxioaming2011@hotmail .com"; // 定 义 字符 串 
$email2 = "The email is liuxiaoshuai 2011@hotmail.com"; 


$asemail = "This is wangxioaming2011@hotmail"; 

$regex = '^[a-zA-20-9_.]+@[a-zA-20-9_]+\. [a-zA-20-9.]+$'; // 定 义 正则 表达 式 
规范 

$regex2 = '[a-zA-20-9_.]+@[a-zA-20-9_]+\.[a-zA-20-9.]+$'; 

if(ereg ($regex, $email, $a)){ // 利 用 正则 表达 式 规范 字符 串 

echo "This is an email."; 
print r($a); 
echo "<br />"; 
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} 

if(ereg($regex2, $email2, $b)){ 
echo "This is a new email."; 

print r($b); 

Seho "<br />"» 

i 

if(ereg($regex, $asemail)){ 
echo "This is an email."; 


}elsef{ 
echo "This is not an email."; 
?> 


运行 结果 如 图 5-12 所 示 。 











@ hpi/localhost P - BO X| Blocalhost 
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This is an email. Array ( [0] =》wangxioaming20118hotmail. com ) 
This is a new email. Array ( [0] => liuxiaoshuai_20118hotmail. com ) 
This is not an email. 








图 5-12 程序 运行 结果 
【案例 分 析 】: 
(1) 其 中 ，$email 就 是 一 个 完整 的 email 字符 串 ， 用 $regex 这 个 正则 规范 ， 也 就 是 匹配 email 
的 规范 来 匹配 $email， 得 出 的 结果 为 图 中 第 一 行 输出 。 
(2) 由 于 ereg() 函 数 的 格式 ，ereg($regex, Semail, $a) 把 匹配 的 子 串 存储 在 名 为 $a 的 数组 中 。 
print_r($a) 打 印 数组 ， 得 出 结果 为 第 一 行 数组 输出 。 
(3) 其 中 , $email2 就 是 一 个 包含 了 完整 email 的 字符 串 。 用 $regex 匹配 , 其 返回 值 必然 为 false。 
用 $regex2 规范 匹配 , 其 返回 值 为 真 。 因为 $regex2 规范 中 去 掉 了 表示 从 字符 串 头 部 开始 的 符号 “^”。 
ereg($regex2, $email2, $b) 把 匹配 的 子 串 存储 在 数组 $b 中 。print_r($b)， 得 到 第 二 行 数组 的 输出 。 
(4) $asemail 字符 串 不 符合 规范 Sregex， 返 回 值 为 false， 得 到 相应 输出 。 
12. 使 用 正则 表达 式 替 换 字符 串 子 串 
完成 字符 串 及 其 子 串 的 匹配 后 ， 如 果 需 要 对 字符 串 的 子 串 进行 替换 ， 也 可 以 使 用 正则 表达 式 
完成 。 这 种 需求 , 比如 把 输入 文本 中 的 unl 完成 可 以 直接 点 击 的 连接 。 此 操作 需要 使 用 ereg_replace() 
和 eregi_replace() 函 数 。 其 中 ereg_replace() 对 大 小 写 敏感 ， 而 eregi_replace() 对 大 小 写 不 敏感 。 其 格 
式 为 : 
ereg_replace (正则 表达 规范 ， 欲 取代 字符 串 子 串 ， 目 标 字 符 串 ) 
提示 : 另外 用 户 也 可 以 使 用 eregi_replace 0 函数 对 字符 串 进 行 替换 , 它 和 ereg_ replace () 函 数 最 
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大 区 别 是 对 字符 大 小 写 敏 感 。 
通过 以 下 实例 ， 介 绍 利用 正则 表达 式 取代 字符 串 子 串 的 方法 和 技巧 。 
【 例 5.13】〔 实 例文 件 ，ch05\5.13.php) 


<?php 
$searchurl = "这 是 搜索 引擎 连接 : http://www.google.com/ 和 http://www.baidu.com/。 





echo ereg_replace (" (http://) ([a-zA-20-9./-_]+)","<a 
href=\"\\0\">\\0</a>", $searchurl1); 
echo "<br />"; 


echo ereg_replace (" (http://) ([a-zA-20-9./-_]+)","<a 
href=\"\\0\">\\2</a>", $searchurl); 

a 

运行 结果 如 图 5-13 所 示 。 





[¢ 碟 要 pupi/localhost P ~ BO X|| Blocalhost x| Ce 


文件 (F) 。 妨 句 (E) 查看 (V) 站 藏 夫 (A) 工具 (T) 帮助 (H) 








这 是 搜索 引 葡 连接:，ht tp: //wwm. google. com/ 和 http: /wm. bai du. com/。 
这 是 搜索 引 葡 连接 ，wmmr. google. com/ 和 ww bai du. com/。 











图 5-13 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 ，$searchurl 里 面包 含 两 个 url 文本 。ereg_replace() 按 照 格式 对 $searchurl 里 的 url 进 
行 匹配 替换 。 
(2) 正则 规范 为 "http:/)([a-zA-Z0-9./- ]+)"， 它 分 为 两 部 分 ， 即 (http:/) 和 ([a-zA-Z0-9./-_]+)， 
前 者 直接 匹配 ， 后 者 用 正则 语法 匹配 。 
(3) 第 一 行 的 输出 ， 替 换 为 "<a href-\"N\O\>\O</a>"。 里 面 的 “\0” 把 反 斜 杠 转 义 后 表示 的 是 
“0”,“\0” 表 示 正 则 规则 中 所 有 部 分 匹配 的 内 容 。 第 二 行 的 输出 ,替换 为 "<a href-\"NOV>\2</a>"， 
里 面 的 “\2” 把 反 斜 杠 转 义 后 表示 的 是 “2”，“\2” 表 示 正 则 规则 中 第 二 部 分 匹配 的 内 容 ， 输 出 
如 图 5-12 所 示 。 依 次 类 推 ，“\1” 表 示 的 是 第 一 部 分 匹配 的 内 容 ， 即 Chttp:/) 。 
13. 使 用 正则 表达 式 切 分 字符 串 
使 用 正则 表达 式 可 以 把 目标 字符 串 按 照 一 定 的 正则 规范 切 分 成 不 同 的 子 串 。 完 成 此 操作 要 用 
到 strtok() 函 数 ， 它 的 语法 格式 为 : 
strtok (正则 表达 式 规范 ， 目 标 字符 串 ) 


这 个 函数 指 以 正则 规范 内 出 现 的 字符 为 准 ， 把 目标 字符 串 切 分 成 若干 个 子 串 ， 并 且 存 入 数组 。 
下 面 通过 实例 ， 介 绍 利 用 正则 表达 式 切 分 字符 串 的 方法 和 技巧 。 
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【 例 5.14】 《实例 文件 :ch0S\5.14.php ) 


<?php 
$string = "Hello world. Beautiful day today."; // 定 义 字符 串 
$token = strtok($string, " "); // 切 分 字符 串 
while (Stoken !== false) // 使 用 while 循环 输出 切 分 后 的 字符 串 


{ 

echo "Stoken<br />"; 
$token = strtok(" "); 
上 


二 


运行 结果 如 图 5-14 所 示 。 








EE 
【€ Er EE ED 
文件 (F) ” 蝙 岛 (E) ”查看 (V) ”收藏 夫 (A) ”工具 (T) ”帮助 (H) 














Hello 
world. 
Beautiful 


day 








图 5-14 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 ，$string 为 包含 多 种 字符 的 字符 串 。strtok($string," ") 对 其 进行 切 分 ， 并 将 结果 存 入 
数组 $token。 
(2) 其 正则 规范 为 " "， 是 指 以 空格 将 字符 串 切 分 。 


5.6 ”实战 演练 一 一 创建 酒店 系统 在 线 订 房 表 
本 实例 主要 创建 酒店 系统 的 在 线 订房 表 ， 其 中 需要 创建 两 个 PHP 文件 ， 具 体 创建 步 又 如 下 。 


在 网 站 主 目 录 下 建立 文件 formstringhandler.php， 输 入 以 下 代码 并 保存 。 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.0rg/TR/xhtml1/ DTD/xhtmll-transitional .dtd"> 
<html xmlns="http://www.w3.0org/1999/xhtml"> 
<HEAD><meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
您 的 订房 信息 : </HEAD> 
<BODY> 
<?php 
$DOCUMENT ROOT = $_SERVER['DOCUMENT ROOT']; 
$customername = trim($ POST['customername']); 
$gender = $_POST['gender']; 
$arrivaltime = $ POST['arrivaltime']; 
$phone = trim($_ POST['phone']); 
$email = trim($ POST['email']); 
$info = trim($ POST['info']); 
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if(!eregi('^[a-zA-20-9 \-\.]+@[a-zA-20-9\-]+\. [a-zA-20-9 \-\.]+$',S$email)){ 
echo "这 不 是 一 个 有 效 的 email 地 址 ， 请 返回 上 页 且 重 试 "; 
exit; 
. 
if(!eregi('^[0-9]$',$phone) and strlen($phone)<= 4 or strlen($phone)>= 15){ 
echo "这 不 是 一 个 有 效 的 电话 号 码 ， 请 返回 上 页 且 重 试 "; 


exit; 
} 
if( $gender == "m"){ 
$customer = "先生 "; 
}else{ 
$customer = "女士 "; 


} 

echo '<p> 您 的 订房 信息 已 经 上 传 ， 我 们 正在 为 您 准备 房间 。 确认 您 的 订房 信息 如 下 :</p>"; 

echo $customername."\t".$customer.' 将 会 在 '.$arrivaltime.' 天 后 到 达 。 您 的 电话 
为 '.$phone ."。 我 们 将 会 发 送 一 封 电子 邮件 到 您 的 email 邮箱 : " .$email."。<br /><br /> 另外 , 我 
们 已 经 确认 了 您 其 他 的 要 求 如 下 : <br /><br />"; 

echo nl2br ($info); 

echo "<p> 您 的 订房 时 间 为 :".date('Y m d H: i: s')."</p>"; 


D> 
</BODY> 

</HTML> 

加 在 网 站 主 目录 下 创建 文件 form4string.html， 输 入 以 下 代码 并 保存 。 

<!DOCTYPE html PUBLIC Ww-//W3C//DTD XHTML :了 Transitional//EN" 


"http://www.w3.0rg/TR/xhtml1/ DTD/xhtmll-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<HEAD><meta http-equiv="Content-Type" content="text/html; charset=gb2312" 
/><h2>GoodHome 在 线 订房 表 。</h2></HEAD> 

<BODY> 
<form action="formstringhandler.php" method="post"> 
<table> 
<tr bgcolor="#3399FF" > 

<td> 客 户 姓 名 :</td> 

<td><input type="text" name="customername" size="20" /></td> 
/tr 
<tr bgcolor="#CCCCCC" > 

<td> 客 户 性 别 : </td> 

<td> 

<select name="gender"> 

<option value="m"> 男 </option> 
<option value="f"> 女 </option> 

</select> 

</td> 
/tr 
<tr bgcolor="#3399FF" > 

<td> 到 达 时 间 :</td> 

<td> 











图 5-15 程序 运行 结果 
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填写 表单 。【 客 户 姓名 】 为 “王小明 ”、【 客 户 性 别 〗 为 “ 男 ”、【 到 达 时 间 】 为 “三 
天 后 ”、【 电 话 】 为 13592XXXX77、【email] 为 wangxiaoming(Qhotmailcom、【 其 他 需求 】 了 为 “两 
壶 开水，【Enter】 一 条 白 毛巾 ，【Enter】 一 个 冰激凌 ”。 单 击 【 确 认 订 房 信息 】 按 钮 ， 浏 览 器 会 
自动 跳 转 至 formstringhandler.php 页 面 ， 显 示 结 果 如 图 5-16 所 示 。 





els hepylocahot P ~ SX|@ locaton x A 
Er ET 

您 的 订房 信息 ， 

你 的 订房 信息 已 经 上 传 ， 我 们 正在 为 您 准备 房间 。 确认 您 的 订房 信息 如 下 : 

王小明 先生 将 会 在 3 天 后 到 达 。 您 的 电话 为 13592YXXX77。 我们 将 会 发 送 一 封 电子 邮件 到 您 
的 cmai] 邮 箱 ，wengxicomingebotnail, com。 





另外 ， 我 们 已 经 确认 了 您 其 他 的 要 求 如 下 。 
两 过 开水 ，【Enter】 一 条 白 毛巾 ， 【Enter] 一 个 广 数 汗 
你 的 订房 时 间 为 :2016 04 19 05: 00: 54 








图 5-16 程序 运行 结果 
【案例 分 析 】: 


(1) $customername = trim($_POST['customername']); 、$phone = trim($_ POST[phone]); 、 
$email = trim($_ POST[email]); 和 $info = trim($_POST['info]); 都 是 通过 文本 输入 框 直接 输入 的 。 所 
以 ， 为 了 保证 输入 字符 串 的 纯粹 性 ， 以 方便 处 理 ， 则 需要 使 用 trim() 来 对 字符 串 前 后 的 空格 进行 清 
除 。 另 外 ，ltrim0 清 除 左 边 的 空格 ，rtrim0 清 除 右 边 的 空格 。 

(2) leregi(^[a-zA-Z0-9_\-\.]+@[a-zA-Z0-9\-]+\.[a-zA-2Z0-9_\-\.]+$',$email) 中 使 用 正则 表达 式 对 
输入 的 email 文本 进行 判断 。 

(3) nl2br() 对 $info 变量 中 的 【Enter] 操 作 , 也 就 是 对 <br 这 操 作 符 进 行 了 处 理 。 在 有 新 行 “ml” 
操作 的 地 方 生成 <br />。 

(4) 其 中 ， 由 于 要 显示 中 文 ， 需 要 对 文字 编码 进行 设置 ，charset=gb2312 就 是 简体 中 文 的 文 
字 编 码 。 


5.7 ”高 手 私房 菜 


技巧 1: 模式 修饰 符 、 单 词 界定 符 和 方 括 号 “[]” 连 用 ， 而 是 和 “/” 在 一 起 使 用 ? 

在 PHP 正则 表达 式 的 语法 当中 ， 一 种 是 POSIX 语法 ， 一 种 是 Perl 语法 。POSIX 语法 是 先前 
所 介绍 的 语法 。Perl 语法 则 不 同 于 POSIX 语法 。Perl 语法 的 正则 表达 是 以 “/” 开 头 和 以 “/” 结 尾 
的 ， 如 “mame/” 便 是 一 个 Perl 语法 形式 的 正则 表达 。 

模式 修饰 符 则 是 在 Perl 语法 正则 表示 中 的 内 容 。 比 如 “i” 表 示 正 则 表达 式 对 大 小 写 不 敏感 ， 
“g” 表 示 找 到 所 有 匹配 字符 ，“m ”表示 把 目标 字符 串 作 为 多 行 字符 串 进行 处 理 ，“s” 表 示 把 目 
标 字符 串 作 为 单行 字符 串 进 行 处 理 ， 忽 略 其 中 的 换行 符 ，“x” 表 示 忽 略 正则 表达 式 中 的 空格 和 备 
注 ，“u” 表 示 在 首次 匹配 后 停止 。 

单词 界定 符 也 是 Perl 语法 正则 表示 中 的 内 容 。 不 同 的 单词 界定 符 表示 不 同 的 字符 界定 范围 。 
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比如 以 下 单词 界定 符 的 表示 意义 为 : 

“\A” 表 示 仅 仅 匹 配 字符 串 的 开头 。“\b” 表 示 匹 配 到 单词 边界 。“\B” 表 示 除 了 单词 边界 ， 
匹配 所 有 。“\d” 表 示 匹 配 所 有 数字 字符 ， 等 同 于 “[0-9]”。“\D ”表示 匹配 所 有 非 数 字 字 符 。”“\s” 
表示 匹配 空格 字符 。“\S” 表 示 匹 配 非 空 格 字 符 。“\w” 表 示 匹 配 字 符 串 ， 如 同 “[a-zA-Z0-9 ]”。 
“\W” 表 示 匹 配 字符 ， 忽 略 下 划 线 和 字母 数字 字符 。 

技巧 2: 支持 Perl 语法 形式 的 正则 表达 式 有 哪些? 

PHP 为 Perl 语法 的 正则 表达 方式 提供 了 如 下 函数 : 

(1) preg_grep() 用 来 搜索 一 个 数组 中 的 所 有 数组 元 素 ， 以 得 到 匹配 元 素 。 

(2) preg_match() 以 特定 模式 匹配 目标 字符 串 。 

(3) preg_match_all() 以 特定 模式 匹配 目标 字符 串 ， 并 且 把 匹配 元 素 作为 元 素 返 回 给 一 个 特定 
数组 。 

(4) preg_quote() 在 每 一 个 正则 表达 式 的 特殊 字符 前 插入 一 个 反 斜 杜 “\”。 

(5) preg_replace() 替 代 所 有 符合 正则 表达 式 格式 的 字符 ， 并 返回 按照 要 求 修改 的 结果 。 

(6) preg_replace_callback() 以 键 值 代替 所 有 符合 正则 表达 式 格式 字符 的 键 名 。 

(7) preg_split() 按 照 正则 模型 切 分 字符 串 。 


5.8 经典 习题 


(1) 制作 一 个 包含 单 引号 和 双 引 号 的 例子 ， 并 分 析 它 们 的 区 别 。 

(2) 制作 一 个 包含 连接 字符 串 的 例子 ， 并 输出 连接 后 的 结果 。 

(3) 制作 一 个 包含 计算 字符 串 长 度 、 蔡 换 字符 串 中 的 空格 、 字 符 串 字 串 截取 和 和 替换 的 例子 。 
(4) 制作 一 个 包含 正则 表达 式 的 例子 。 

(5) 制作 一 个 酒店 系统 在 线 订房 表 的 例子 。 


Nev 


第 6 章 PHP 数组 


数组 在 PHP 中 是 极为 重要 的 数据 类 型 。 本 章 将 介绍 什么 是 数组 ， 数 组 的 类 型 、 数 组 的 构造 、 遍 历 
数组 、 数 组 排序 、 向 数组 中 添加 和 删除 元 素 、 查 询 数组 中 的 指定 元 素 、 统 计数 组 的 元 素 个 数 、 删 除数 组 
中 重复 的 元 素 、 数 组 的 序列 化 等 操作 。 通 过 本 章 的 学 习 ， 读 者 可 以 掌握 数组 的 常用 操作 和 技巧 。 

本 章 学 习 目标 

了 解 什么 是 数组 

熟悉 数组 的 类 型 
掌握 数组 构建 的 方法 
掌握 遍历 数组 的 方法 
掌握 数组 排序 的 方法 

掌握 数组 和 字符 串 之 间 转 换 的 方法 
掌握 向 数组 中 添加 和 删除 元 素 的 方法 
掌握 查询 数组 中 指定 元 素 的 方法 
掌握 统计 元 素 个 数 的 方法 

掌握 删除 数组 中 重复 元 素 的 方法 
掌握 调换 数组 中 的 键 值 和 元 素 值 的 方法 
掌握 如 何 实现 数组 的 序列 化 


6.1 什么 是 数组 


什么 是 数组 ? 数组 ， 就 是 用 来 存储 一 系列 数值 的 地 方 。 数 组 〈array) 是 非常 重要 的 数据 类 型 。 
相对 于 其 他 的 数据 类 型 ， 它 更 像 是 一 种 结构 ， 而 这 种 结构 可 以 存储 一 系列 的 数值 。 

数组 中 的 数值 被 称 为 数组 元 素 (element) 。 每 一 个 元 素 都 有 一 个 对 应 的 标识 〈index) ， 也 称 
作 键 值 (key) 。 通 过 这 个 标识 ， 可 以 访问 数组 元 素 。 数 组 的 标识 可 以 是 数字 也 可 以 是 字符 串 。 

例如 一 个 班级 通常 有 十 几 个 人 ， 如 果 要 找 出 某 个 学 生 ， 可 以 利用 学 号 来 区 分 每 一 个 队员 ， 这 
时 ， 班 级 就 是 一 个 数组 ， 而 学 号 就 是 下 标 ， 如 果 指 明 学 号 ， 就 可 以 找到 对 应 的 学 生 。 


6.2 ”数组 的 类 型 
数组 分 为 数字 索引 数组 和 关联 索引 数组 。 本 节 将 详细 讲述 这 两 种 数组 的 使 用 方法 。 


6.2.1 数字 索引 数组 


数字 索引 数组 是 最 常见 的 数组 类 型 ， 默 认 从 0 开始 计数 。 另 外 ， 数 组 变量 在 使 用 时 即 可 创建 ， 
创建 时 即 可 使 用 。 
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声明 数组 的 方法 有 两 种 。 


(1) 使 用 arrayO 函 数 声明 数组 ， 具 体 的 声明 数组 方式 如 下 。 
array 数组 名 称 〈[mixed]) ， 其 中 参数 mixed 的 语法 为 key=>value， 如 果 有 多 个 mixed， 可 以 
用 逗号 分 开 ， 分 别 定 义 了 索引 和 值 。 
$arr = array("1"=> "空调 "，"2"=>" 冰 箱 "，"3"=>" 洗 衣 机 "， "4"=>" 电 视 机 ") 7 
利用 array() 函 数 定义 比较 方便 ， 可 以 只 给 出 数组 的 元 素 值 ， 而 不 需要 给 出 键 值 ， 例 如 : 
$arr = array(“" 空 调 ", "冰箱 ", "洗衣 机 "," 电 视 机 "); 


(2) 直接 通过 为 数组 元 素 赋值 的 方式 声明 数组 。 
如 果 在 创建 数组 时 不 知道 数组 的 大 小 ， 或 者 数组 的 大 小 可 能 会 根据 实际 情况 发 生变 化 ， 此 时 
可 以 使 用 直接 赋值 的 方式 声明 数组 ， 例 如 : 
$arr[1]= "空调 "; 
$arr[2]= "冰箱 "; 
$arr[3]= "洗衣 机 "; 
$arr[4]= "电视 机 "; 
下 面 以 酒店 网 站 系统 中 酒店 房价 为 例 进 行 讲解 。 
【 例 6.1】〔 实 例文 件 : ch06\6.1.php) 
<?php 
$roomtypes = array( ' 单 床 房 ',' 标 准 间 '，' 三 床 房 ','VIP 套房 ') ; 
echo 
Sroomtypes [0] ."\t".$roomtypes[1]."\t".$roomtypes[2]."\t".$roomtypes[3]."<br 
/>"; 
echo "$roomtypes[0] Sroomtypes[1] $roomtypes[2] $roomtypes[3] <br />"; 
$roomtypes[0] = ' 单 人 大 床 房 '; 


echo "$roomtypes[0] $roomtypes[1] Sroomtypes [2] $roomtypes[3]<br />"; 
2> 


运行 结果 如 图 6-1 所 示 。 


OE DB tofocahos P- SOx | 本 localhost 
文 伯 并 呈 日 “ 二 看 M|。 改 生 大 凡 。 工 RD NaH) 











GoodHome 房 间 类 型 。 








图 6-1 程序 运行 结果 
【案例 分 析 】 : 
(1) 其 中 ，$roomtypes 为 一 维 数组 ， 用 关键 字 array 声明 ， 并 且 用 “=” 赋值 给 数组 变量 
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$roomtypes 。 

(2) ' 单 床 房 '、' 标 准 间 '、' 三 床 房 ' 和 'VIP 套房 ' 为 数组 元 素 ， 且 这 些 元 素 为 字符 串 型 ， 用 单 引 
号 方式 表示 。 每 个 数组 元 素 用 “，” 分 开 。echo 命令 直接 打印 数组 元 素 ， 元 素 索引 默认 从 0 开始 ， 
所 以 第 一 个 数组 元 素 为 Sroomtypes[0]。 

(3) 数组 元 素 可 以 直接 通过 “=” 号 赋值 ， 如 $roomtypes[0] = ' 单 人 大 床 房 ';' ，echo 打印 后 为 
“ 单 人 大 床 房 ”。 


6.2.2 关联 索引 数组 


关联 数组 的 键 名 可 以 是 数值 和 字符 串 混合 的 形式 ， 而 不 像 数 字 索 引 数 组 的 键 名 只 能 为 数字 。 
所 以 判断 一 个 数组 是 否 为 关联 数组 的 依据 是 : 数组 中 的 键 名 是 否 存在 不 是 数字 的 字符 ， 如 果 存 在 ， 
则 为 关联 数组 。 
下 面 以 使 用 关联 索引 数组 编写 酒店 房间 类 型 为 例 进行 讲解 。 
【 例 6.2】 (实例 文件 ， ch06\6.2.php) 
<?php 
$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198,'VIP 套房 
"=> 368); 
echo $prices_per_day[' 标 准 间 '] ."<br />"; 
x 


运行 结果 如 图 6-2 所 示 。 
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文 作 (个 。 网 各 日 。 玫 看 履 基 (人 ) 工具 TT 部 肥 0H) 
GoodHome 房 间 类 型 。 


268 














图 6-2 程序 运行 结果 
【案例 分 析 】: 


其 中 echo 命令 直接 指定 数组 $prices_per_day 中 的 关键 字 索 引 standardroom (是 一 个 字符 串 ) 
便 可 打印 出 数组 元 素 268 (是 一 个 整 型 数字 ) 。 


6.3 PHP 常量 数组 


在 PHP 5.6 中 仅 能 通过 const 定义 常量 数组 ， 例 如 以 下 例子 : 


<?php 
// 使 用 const 函数 来 定义 数组 
const arr = array( "空调 ", "冰箱 ", "洗衣 机 ", "电视 机 "); 


echo arr[2]; 
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> 
以 上 程序 执行 后 输出 结果 为 : 洗衣 机 。 
PHP 7 可 以 通过 define() 来 定义 常量 数组 。 例 如 以 下 例子 : 
<?php 
// 使 用 define 函数 来 定义 数组 
define (' 学 员 '，[ 
' 张 笑 笑 '， 
' 杨 洋 '， 
C= 
Ths 


print (学 员 [1]); 
?> 


以 上 程序 执行 后 输出 结果 为 : 杨洋 。 


6.4 数组 构造 
按照 数组 的 构造 来 分 ， 可 以 把 数组 分 为 一 维 数组 和 多 维 数组 。 


6.4.1 一 维 数组 


数组 中 每 个 数组 元 素 都 是 单个 变量 ， 不 管 是 数字 索引 还 是 关联 索引 ， 这 样 的 数组 为 一 维 数组 。 
【 例 6.3】 实 例文 件 : ch06\6.3.php) 
<?php 
$roomtypes = array(' 单 床 房 ',' 标 准 间 ',' 三 床 房 ', 'VIP 套房 ') ; 
$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198,'VIP 套房 
'=> 368); 
2 


其 中 $roomtypes 和 $prices_per_day 都 是 一 维 数组 。 
6.4.2 ”多 维 数组 


数组 也 是 可 以 “ 嵌 套 ”的 ， 即 每 个 数组 元 素 也 可 以 是 一 个 数组 ， 这 种 含有 数组 的 数组 就 是 多 
维 数组 ， 例 如 : 


<?php 
$roomtypes = array( array( 'type'=>' 单 床 房 '， 
"'info'=>' 此 房间 为 单 人 单间 。'， 
'price per day'=>298 
), 
array ( 'type'=>' 标 准 间 '， 
"'info'=>' 此 房间 为 两 床 标准 配置 。'， 
'price per day'=>268 
) 
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array( 'type'=>' 三 床 房 '， 
"'info'=>' 此 房间 备 有 三 张 床 '， 
'price per day'=>198 
)， 
array( 'type'=>'VIP 套房 '， 
"info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
'price per day'=>368 
) 


); 


人 


其 中 $roomtypes 就 是 多 维 数组 。 这 个 多 维 数组 其 实 包含 两 个 维 数 ， 有 点 像 数据 库 中 的 表格 ， 


第 一 个 array 里 面 的 每 个 数组 元 素 都 是 一 个 数组 ， 而 这 些 数 组 就 像 数 据 二 维 表 品 





Fh 的 一 行 记录 。 这 些 





包含 在 第 一 个 array 里 面 的 array 又 都 包含 3 个 数组 元 素 ， 分 别 是 3 个 类 型 的 信息 ， 这 就 像 数据 二 








此 房间 备 有 三 张 床 “ 
此 店 间 为 VIP 两 间 


维 表 中 的 字段 。 
可 将 上 面 的 数组 绘制 成 图 ， 如 图 6-3 所 示 。 
| 2 WN B I & WE | 
1 type info price_per_day 
2 单 床 房 此 房间 为 单 人 单间 。 298 array 
3 标准 间 此 房间 为 两 床 标准 配置 268 array 
4 三 床 房 198 
5 
6 





图 6-3 程序 运行 结果 


其 实 ，$roomtypes 就 代表 了 这 样 的 一 个 数据 表 。 
如 果 出 现 了 两 维 以 上 的 数组 ， 比 如 三 维 数组 ， 例 如 : 


<?php 
Sbuidling = array(array( array( 'type'=>' 单 床 房 '， 
"info'"=>" 此 房间 为 单 人 单间 。 "， 
"Price_Per_day'=>298 
a; 
array( 'type'=>' 标 准 间 '， 
'info'=>' 此 房间 为 两 床 标准 配置 。'， 
'price per day'=>268 
), 
array( 'type'=>' 三 床 房 '， 
"'info'=>' 此 房间 备 有 三 张 床 '， 
'price per day'=>198 
), 
array( 'type'=>'VIP 套房 '， 
"'info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
'price per day'=>368 
) 
), 
array( array( 'type'=>' 普 通 餐 厅 包 房 '， 
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"info'=>" 此 房间 为 普通 餐厅 包 房 。" 
"roomid'=>201 
)， 
array( 'type'=>' 多 人 餐厅 包 房 '， 
"'info'=>' 此 房间 为 多 人 和 餐厅 包 房 。' 
'roomid'=>206 
)， 
array ( 'type'=>' 豪 华 餐 厅 包 房 '， 
"'info'=>' 此 房间 为 豪华 餐厅 包 房 。' 
"zoomid'=>208 
), 
array( 'type'=>'VIP 和 餐厅 包 房 '， 
"info"=>" 此 房间 为 VIP 餐厅 包 房 '， 


"roomid'=>310 


Dr 
?> 
这 个 三 维 数组 ， 在 原来 的 二 维 数组 后 面 又 增加 了 一 个 二 维 数组 ， 给 出 了 餐厅 包 房 的 数据 二 维 
表 信息 。 把 这 两 个 二 维 数组 作为 更 外 围 array 的 两 个 数组 元 素 ， 就 产生 了 第 三 维 。 这 个 表述 等 于 用 
两 个 二 维 信息 表 表 示 一 个 名 为 Sbuilding 的 数组 对 象 ， 如 图 6-4 所 示 。 
[21 A ea Cina D E 
此 玉 间 为 划 久 单间 、 
配置 











ESEeomonaoameawnsr 


和 | ARRAY (三 维 ) 
图 6-4 程序 运行 结果 


6.5 遍历 数组 
所 谓 数组 的 遍历 是 要 把 数组 中 的 变量 值 读 取出 来 。 下 面 讲述 遍历 数组 的 常见 方法 。 
6.5.1 遍历 一 维 数字 索引 数组 
下 面 讲解 如 何 通 过 循环 语句 遍历 一 维 数字 索引 数组 。 此 案例 中 用 到 了 for 循环 和 foreach 循环 。 
【 例 6.4】 (实例 文件 : ch06\6.4.php) 


<?php 
$roomtypes = array( ' 单 床 房 ',' 标 准 间 ',' 三 床 房 ','VIP 套房 ') ; 
Fore (sd 0 3 tt 
echo $roomtypes[$i]." (for 循环 ) <br />"; 





运行 结果 如 图 6-5 所 示 。 





6-5 程序 运行 结果 
【案例 分 析 】: 


(1) for 循环 只 进行 了 0、1、2 三 次 ; 
(2) foreach 循环 则 列 出 了 数组 中 的 所 有 数组 元 素 。 


6.5.2 ”遍历 一 维 联合 索引 数组 


下 面 以 遍历 酒店 房间 类 型 为 例 对 联合 索引 数组 进行 遍历 。 
【 例 6.5】〔 实 例文 件 : ch06\6.5.php) 
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运行 结果 如 图 6-6 所 示 。 
































|S teenocamon p - So x [Siocon 
EEC OVER IT 
GoodHome 房 间 类 型 。 











图 6-6 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 ，foreach ($prices_per_day as $price){} 遍历 数组 元 素 ， 所 以 输出 4 个 整 型 数字 。 而 
foreach ($prices_per day as $key => $value)f} 则 除了 遍历 数组 元 素 ， 还 遍历 其 所 对 应 的 关键 字 ， 如 
onebedroom 是 数组 元 素 298 的 关键 字 。 

(2) 这 段 程序 中 使 用 了 while 循环 ， 还 用 到 了 几 个 新 的 函数 ， 即 reset0、each() 和 list0)。 由 于 
在 前 面 的 代码 中 ，$prices_per_day 已 经 被 foreach 循环 遍历 过 ， 而 内 存 中 的 实时 元 素 为 数组 的 最 后 
一 个 元 素 。 因 此 ， 如 果 想 用 while 循环 来 遍历 数组 ， 就 必须 用 reset() 函 数 把 实时 元 素 重 新 定义 为 数 
组 的 开头 元 素 。each() 则 是 用 来 遍历 数组 元 素 及 其 关键 字 的 函数 。list0 则 是 把 each0 中 的 值 分 开 赋 
值 和 输出 的 函数 。 


6.5.3 ”遍历 多 维 数组 


下 面 以 使 用 多 维 数组 编写 房间 类 型 为 例 进行 遍历 ， 有 具体 操作 步骤 如 下 。 
【 例 6.6】〔 实 例文 件 ，ch06\6.6.php) 
<?php 
$roomtypes = array( array( 'type'=>' 单 床 房 '， 
"'info'=>' 此 房间 为 单 人 单间 。"'， 
'Pprice per day'=>298 
), 
array ( 'type'=>' 标 准 间 '， 
"'info'=>' 此 房间 为 两 床 标准 配置 。'， 
"Price per day'=>268 
ns 
array( 'type'=>' 三 床 房 '， 
"'info'=>' 此 房间 备 有 三 张 床 '， 
"Price per day'=>198 
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), 
array( 'type'=>'VIP 套房 
"info'=>' 此 房间 为 VIP 两 间 内 外 套房 "， 
"Price_ per day'=>368 
) 
Ds 
for ($row = 0; Srow < 4; Srow++){ 
while (list($key, $value ) = each( $roomtypes[$row])){ 
echo "$key:$value"."\t |"; 
1 
echo '<br />'; 
1 


人 


运行 结果 如 图 6-7 所 示 。 
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GoodHome 房 间 类 型 (多 维 数组 ) 。 
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图 6-7 程序 运行 结果 
【案例 分 析 】: 
(1) 其 中 ，$roomtypes 中 的 每 个 数组 元 素 都 是 一 个 数组 ， 而 作为 数组 元 素 的 数组 又 都 有 三 个 
拥有 键 名 的 数组 元 素 。 
(2) 使 用 for 循环 配合 eachO、list(0) 函 数 来 遍历 数组 元 素 ， 便 得 到 如 图 6-7 所 示 的 输出 。 


6.6 数组 排序 
本 节 主 要 讲述 如 何 对 一 维和 多 维 数组 进行 排序 操作 。 
6.6.1 一 维 数组 排序 
下 面 通过 以 下 实例 展示 如 何 对 数组 排序 ， 具 体操 作 步 又 如 下 。 
【 例 6.7】〔 实 例文 件 ，ch06\6.7.php) 
<?php 
$roomtypes = array ( ' 单 床 房 ',' 标 准 间 ',' 三 床 房 ', 'VIP 套房 '); 


S$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, 'VIP 套房 
"=> 368); 


sort ($roomtypes); 





运行 结果 如 图 6-8 所 示 。 


| 


让 


TT 











图 6-8 程序 运行 结果 
【案例 分 析 】: 


(1) 这 段 代码 是 关于 数组 排序 的 内 容 , 涉及 sort()、asort0、ksort()、rsort()、arsort() 和 krsort()。 
其 中 ，sort0 是 默认 排序 。asort0 根 据 数组 元 素 的 值 的 升序 排序 。ksort() 根 据 数组 元 素 的 键 值 ， 也 就 
是 关键 字 的 升序 排序 。 
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(2) rsort()、arsort() 和 krsort() 则 正好 与 所 对 应 的 升序 排序 相反 ， 都 为 降序 排序 。 


6.6.2 多维 数 组 排序 


对 于 一 维 数组 ， 通 过 sort() 等 一 系列 的 排序 函数 ， 就 可 以 对 它 进行 排序 。 而 对 于 多 维 数组 ， 排 
序 就 没有 那么 简单 了 。 首 先 需 要 设 定 一 个 排序 方法 ， 也 就 是 建立 一 个 排序 函数 。 再 通过 usort() 函 数 
对 特定 数组 采用 特定 排序 方法 来 进行 排序 。 下 面 的 案例 介绍 多 维 数组 排序 ， 具 体 步骤 如 下 。 

【 例 6.8】〔 实 例文 件 : ch06\6.8.php) 


<?php 
Sroomtypes = array( array( 'type'=>' 单 床 房 '， 
"info'=>' 此 房间 为 单 人 单间 。"'， 
'Price per day'=>298 


js 
array( 'type'=>' 标 准 间 '， 
"'info'=>' 此 房间 为 两 床 标准 配置 。'， 
'Price per day'=>268 
) ， 
array( 'type'=>' 三 床 房 '， 
"'info'=>' 此 房间 备 有 三 张 床 '， 
"Price per day'=>198 
Di 
array( 'type'=>'VIP 套房 '， 
"info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
'Price per day'=>368 


); 

function compare($x, $y){ 
if ($x['price per day'] == $y['price per day']){ 
return 0; 

}else if ($x['price per day'] < $y['price per day']){ 
return -1; 

}else{ 
return 1; 

} 

1 


usort ($roomtypes, 'compare'); 


for ($row = 0; $row < 4; $rowt++){ 
reset (Sroomtypes [$row] ) ; 
while (list($key, $value ) = each( $roomtypes[$row])){ 

echo "$key:$value"."\t |"; 

} 
echo '<br />'; 

| 

2 


运行 结果 如 图 6-9 所 示 。 
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type: 三 库 启 |info: 此 房间 畜 有 三 张 床 
type: 奈 并 问 两 床 标准 配置 。 
type; 草 床 所 





单 人 单间 。 ip 
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图 6-9 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 ， 函 数 compare(0 定 义 了 排序 方法 ， 通 过 对 price_per_day 这 一 数组 元 素 的 对 比 ， 进 
行 排序 。 然 后 usort0 采 用 compare 方法 对 $roomtypes 这 一 多 维 数组 进行 排序 。 
(2) 如 果 这 个 排序 的 结果 是 正 向 排序 ， 那 么 如 何 进行 反 向 排序 呢 ? 这 就 需要 对 排序 方法 进行 


调整 。 其 中 ，recompare() 就 是 上 一 段 程序 中 compare() 的 相反 判断 ， 同 样 采用 usort0) 函 数 输出 后 ， 
得 到 如 图 6-9 所 示 的 排序 ， 正 好 与 前 一 段 程序 输出 顺序 相反 。 


6.7 ”字符 串 与 数组 的 转换 


可 使 用 explode() 和 implode() 函 数 来 实现 字符 串 和 数组 之 间 的 转换 。Explode 用 于 把 字符 串 按照 
一 定 的 规则 拆 分 为 数组 中 的 元 素 , 并 且 形 成 数组 。 Implode() 函 数 用 于 把 数组 中 的 元 素 按照 一 定 的 连 
接 方式 转换 为 字符 串 。 


下 面 的 例子 介绍 使 用 explode() 和 implode() 函 数 来 实现 字符 串 和 数组 之 间 的 转换 。 
【 例 6.9】 实 例文 件 : ch06\6.9.php) 


<?php 
$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198,'VIP 套房 
'=> 368); 
echo implode(' 元 每 天 / '，,$prices_ per _ day).'<br />'; 


$roomtypes =' 单 床 房 ,标准 间 , 三 床 房 ,VIP 套房 '; 


print _r(explode(',',$roomtypes)); 
2> 


运行 结果 如 图 6-10 所 示 。 
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图 6-10 程序 运行 结果 





【案例 分 析 】: 


(1) 其 中 ，$prices_per day 为 数组 。implode(' 元 每 天 /',$prices_per_day) 对 $prices_per_day 中 的 
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数组 元 素 中 间 添 加 连接 内 容 ， 也 叫 元 素 胶水 〈glue) ， 把 它们 连接 成 一 个 字符 串 输出 。 这 个 元 素 胶 
水 (glue) 只 在 元 素 之 间 。 

(2) $roomtypes 为 一 个 由 “，” 号 分 开 的 字符 串 。explode(",,$roomtypes) 确 认 分 隔 符 为 “，” 
号 后 ， 以 “，” 号 为 标记 把 字符 串 中 的 字符 分 为 4 个 数组 元 素 ， 并 且 生 成 数组 并 返回 。 


6.8 向 数组 中 添加 和 删除 元 素 
数组 创建 完成 后 ， 用 户 还 可 以 继续 添加 和 删除 元 素 ， 从 而 满足 实际 工作 的 需要 。 
6.8.1 向 数组 中 添加 元 素 


数组 是 数组 元 素 的 集合 。 如 果 向 数组 中 添加 元 素 ， 就 像 往 一 个 盒子 里 面 放 东 西 。 这 就 涉及 “ 先 
进 先 出 ”或 是 “后 进 先 出 ”的 问题 。 
@ ”先进 先 出 ， 有 点 像 排 队 买 火车 票 。 先 进入 购买 窗口 区 域 ， 购 买 完 成 之 后 从 旁边 的 出 口 出 
去 。 
@ 后进 先 出 ， 有 点 像 给 枪 的 弹 夹 上 子弹 。 最 后 押 上 的 那 一 颗 子 弹 是 要 最 先 打 出 去 的 。 


PHP 对 数组 添加 元 素 的 处 理 使 用 push 、pop、shift 和 unshift 函数 来 实现 , 可 以 实现 先进 先 出 ， 
也 可 以 实现 后 进 先 出 。 
下 面 通过 实例 介绍 在 数组 前 面 添加 元 素 ， 以 实现 后 进 先 出 。 
【 例 6.10】〔 实 例文 件 ，ch06\6.10.php) 
<?php 
$clients = array(' 李 丽 丽 ',' 赵 大 勇 ',' 方 芳 芳 '); 
array_unshift ($clients,' 王 小 明 ', ' 刘 小 帅 '); 
print r($clients); 
?> 


运行 结果 如 图 6-11 所 示 。 
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Array《 [0] =》 王小明 [1] =》 刘 小 帅 [2] =》 李 而 丽 [3] =》 赵 大 勇 [4] =》 方芳 芳 ) 


图 6-11 程序 运行 结果 
【案例 分 析 】 : 


(1) 其 中 ， 数 组 $clients 原本 拥有 3 个 数组 元 素 。 array_unshift() 向 数组 $clients 的 头 部 添加 了 
数组 元 素 ' 王 小 明 '、' 刘 小 帅 '。 最 后 通过 print_r() 输 出 ， 通 过 其 数字 索引 可 以 知道 添加 元 素 的 位 置 。 
(2) array_unshift() 函 数 的 格式 为 : 
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array_unshift (目标 数组 ，[ 预 添加 数组 元 素 ， 预 添加 数组 元 素 ，.…] ) 
同样 通过 以 下 实例 介绍 如 何在 数组 后 面 添加 元 素 ， 以 实现 先进 先 出 。 
【 例 6.11】〔 实 例文 件 ，ch06\6.11.php) 
<?php 
$clients = array('" 李 丽 丽 "，"' 赵 大 勇 "'，' 方 芳 芳 ') 7 
array_push ($clients,，' 王 小 明 ', ' 刘 小 帅 '); 


print r($clients); 
We 


运行 结果 如 图 6-12 所 示 。 
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图 6-12 程序 运行 结果 
【案例 分 析 】: 
(1) 其 中 ,数组 $clients 原本 拥有 三 个 数组 元 素 。 array_push() 向 数组 $clients 的 尾部 添加 了 数 
组 元 素 ' 王 小 明 '、' 刘 小 帅 '。 最 后 通过 print_r0 输 出 ， 通 过 其 数字 索引 可 以 知道 添加 元 素 的 位 置 。 
(2) array_push() 函 数 的 格式 为 : 
array_push (目标 数组 ，[ 预 添加 数组 元 素 ， 预 添加 数组 元 素 ，.….] ) 
push 就 是 “ 推 ” 的 意思 ， 这 个 过 程 就 像 排 队 的 时 候 把 人 从 队伍 后 面向 前 推 。 
6.8.2 ”从 数组 中 删除 元 素 
从 数组 中 删除 元 素 是 添加 元 素 的 逆 过 程 。 PHP 使 用 array_shift() 和 array_pop() 函 数 分 别 从 数组 
的 头 部 和 尾部 删除 元 素 。 
下 面 的 例子 介绍 如 何在 数组 前 面 删除 第 一 个 元 素 并 返回 元 素 值 。 
【 例 6.12】 (实例 文件 :ch06\6.12.php) 
<?php 
$serivces = array(' 洗 衣 ', ' 订 和 餐 ',' 导 游 ', ' 翻 译 '); 


$deletedserivces = array shift ($serivces); 
echo $deletedserivces."<br />"; 
print r($serivces); 

> 


运行 结果 如 图 6-13 所 示 。 
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删除 数组 开头 的 第 一 个 元 素 。 


许 胡 
Array ( [0] => 订餐 [1] => 导游 [2] => 镭 译 ) 











图 6-13 程序 运行 结果 


【案例 分 析 】: 
(1) 其 中 ， 数 组 $serivces 原本 拥有 4 个 数组 元 素 。 array_shift() 从 数组 $serivces 的 头 部 删除 
了 第 一 个 数组 元 素 , 并 且 直 接 把 所 删除 的 元 素 值 返 回 , 且 赋 值 给 变量 $deletedserivces。 最 后 通过 echo 


输出 $deletedserivces， 并 用 print_r0 输 出 $serivces。 
(2) array_ shift() 函 数 仅仅 删除 目标 数组 的 头 一 个 数组 元 素 ， 它 的 格式 如 下 : 


array_ shift (目标 数组 ) 
以 上 为 数字 索引 数组 ， 如 果 是 带 键 值 的 联合 索引 数组 ， 它 的 效果 相同 ， 返 回 所 删除 元 素 的 元 


同样 ， 通 过 下 面 的 实例 介绍 如 何在 数组 后 面 删除 最 后 一 个 元 素 并 返回 元 素 值 。 
【 例 6.13】 (实例 文件 ，ch06\6.13.php) 


<?php 

$serivces = array('s1l'=>' 洗 衣 ', 's2'=>' 订 和 餐 ','s3'=>' 导 游 ', 's4'=>' 翻 译 '); 
$deletedserivces = array pop ($serivces); 
echo $deletedserivces."<br />"; 
Print r($serivces); 


?> 
运行 结果 如 图 6-14 所 示 。 
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删除 数组 结尾 的 最 后 一 个 元 素 。 
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图 6-14 程序 运行 结果 


【案例 分 析 】: 
(1) 其 中 ， 数 组 $serivces 原本 拥有 4 个 数组 元 素 。 array_pop() 从 数组 $serivces 的 尾部 删除 了 
最 后 一 个 数组 元 素 ， 并 且 直 接 把 所 删除 的 元 素 值 返 回 ， 且 赋值 给 了 变量 $deletedserivces。 最 后 通过 


echo 输出 $deletedserivces， 以 及 用 print_r() 输 出 $serivces。 
(2) array_popO 函 数 仅仅 删除 目标 数组 的 最 后 一 个 数组 元 素 。 它 的 格式 如 下 : 


array_ pop〔 目 标 数组 ) 
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这 个 例子 中 的 数组 是 一 个 联合 数组 。 


6.9 查询 数组 中 指定 元 素 


数组 是 一 个 数据 集合 ， 能 够 在 不 同类 型 的 数组 和 不 同 结构 的 数组 内 确定 某 个 特定 元 素 是 否 存 
在 , 是 必要 的 。 PHP 提供 in_array(0、array_key_exists()、array_search()、array_keys0 和 array_values() 
函数 ， 按 照 不 同方 式 查询 数组 元 素 。 

通过 下 面 的 例子 介绍 如 何 查询 数字 索引 数组 和 联合 索引 数组 ， 两 者 都 是 一 维 数组 。 

【 例 6.14】 (实例 文件 ，ch06\6.14.php ) 


<?php 
$roomtypes = array( ' 单 床 房 ',' 标 准 间 ',' 三 床 房 ', "VIP 套房 ') ; 
$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198,'VIP 套房 
'=> 368); 


if (in array( ' 单 床 房 ', $roomtypes)){echo ' 单 床 房 元 素 在 数组 $roomtypes 中 。<br 
V2 

if (array_key_exists( ' 单 床 房 ', $prices_per_day) ) {echo ' 键 名 为 单 床 房 的 元 素 在 数组 
S$prices per day 中 。<br />';} 

if (array_search( 268,$prices per day)){echo ' 值 为 268 的 元 素 在 数组 
$prices per day 中 。<br />';} 


$prices per day keys = array_ keys($prices per day); 
print _r($prices per day keys); 

$prices per day values = array values ($prices per day); 
print _r($prices per day values); 

2 


运行 结果 如 图 6-15 所 示 。 




















图 6-15 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 ， 数 组 $roomtypes 为 一 个 数字 索引 数组 。in_array( ' 单 床 房 ,$roomtypes) 判定 元 素 ' 
单 床 房 ' 是 否 在 数组 $roomtypes 中 ， 如 果 在 ， 则 返回 tue。 让 语句 得 到 返回 值 为 真 ， 便 打印 表述 。 

(2) 数组 $prices_per_day 为 一 个 联合 索引 数组 。array_key_exists( " 单 床 房 ,$prices_per_day) 判 
定 一 个 键 值 为 ' 单 床 房 ' 的 元 素 是 否 在 数组 Sprices_per_day 中 ,如 果 在 ， 则 返回 true。 让 语句 得 到 返回 
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值 为 真 ， 便 打印 表述 。array_key_exists( ) 是 专门 针对 联合 数组 的 “ 键 名 ”进行 查询 的 函数 。 

(3)array_search() 是 专门 针对 联合 数组 的 “元 素 值 ” 进 行 查询 的 函数 。 同 样 针对 $prices_per_day 
这 个 联合 数组 。array_search( 268,$prices_per _ day) 判定 一 个 元 素 值 为 268 的 元 素 是 否 在 数组 
Sprices_per_day 中 ， 如 果 在 ， 则 返回 true。 让 语句 得 到 返回 值 为 真 ， 便 打印 表述 。 

(4) 函数 array_keys() 是 取得 数组 “ 键 值 ”， 并 把 键 值 作为 数组 元 素 输出 为 一 个 数字 索引 数组 
的 函数 ， 主 要 用 于 联合 索引 数组 。array_keys($prices_per_ day) 获 得 数组 $prices_per day 的 键 值 ， 并 
把 它 赋 值 给 变量 $prices_per_ day_keys 为 一 个 数组 。 用 print_r() 打 印 表 述 。 函 数 array_keys() 虽 然 也 
可 以 取得 数字 索引 数组 的 数字 索引 ， 但 是 这 样 做 意义 不 大 。 

(5) 函数 array_values() 是 取得 数组 元 素 的 “元 素 值 ”， 并 把 元 素 值 作为 数组 元 素 输出 为 一 个 
数字 索引 数组 的 函数 。array_values($prices_per_day) 获得 数组 $Sprices_per_day 的 元 素 值 ， 并 把 它 赋 
值 给 变量 $prices_per_day_values， 为 一 个 数组 ， 用 print_r() 打 印 表述 。 

这 几 个 函数 只 是 针对 一 维 数组 ， 无 法 用 于 多 维 数组 。 它 们 在 查询 多 维 数组 的 时 候 ， 只 会 处 理 
最 外 围 的 数组 ， 其 他 内 绒 的 数组 都 作为 数组 元 素 处 理 ， 不 会 得 到 内 和 骨 数 组 内 的 键 值 和 元 素 值 。 


6.10 ”统计 数组 元 素 个 数 


使 用 count() 函 数 统计 数组 的 元 素 个 数 。 
下 面 通过 实例 介绍 如 何 使 用 count() 函 数 统计 数组 的 元 素 个 数 。 
【 例 6.15】〔 实 例文 件 ，ch06\6.15.php) 
<?php 
$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198,'VIP 套房 
"=> 368); 
$roomtypesinfo = array( array( 'type'=>' 单 床 房 '， 
"info'=>' 此 房间 为 单 人 单间 。'， 
'price per day'=>298 





)， 
array( 'type'=>' 标 准 间 '， 
"info"=>" 此 房间 为 两 床 标准 配置 。"， 
"Price_Per_day'=>268 
)， 
array( 'type'=>' 三 床 房 '， 
"'info'=>' 此 房间 备 有 三 张 床 '， 
'price per day'=>198 
)， 
array( 'type'=>'VIP 套房 '， 
"'info'=>' 此 房间 为 VIP 两 间 内 外 套房 '， 
'price per day'=>368 
) 
); 
echo count ($prices_per_day) . ' 个 元 素 在 数组 Sprices_Per day 中 。<br />'; 
echo count (Sroomtypesinfo) .' 个 内 檬 数组 在 二 维 数组 Sroomtypesinfo 中 。<br />'7 
echo count ($Sroomtypesinfo,1).' 个 元 素 $Sroomtypesinfo 中。<br />'; 
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运行 结果 如 图 6-16 所 示 。 
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用 count 函 数 统计 数组 元 素 个 数 。 


4 个 元 素 在 数组 $prices_per_day 中 。 
4 个 内 志 数 组 在 二 维 数 组 jroomtypesinfo 中 。 
15 个 元 村 4roomtypesinfo 中 。 








图 6-16 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 ， 数 组 $prices_per day 通过 count() 函 数 返 回 整数 4。 因 为 数组 $prices_per day 有 4 
个 数组 元 素 。 
(2) 数组 $roomtypesinfo 为 一 个 二 维 数组 。count($roomtypesinfo) 只 统计 了 数组 $roomtypesinfo 
内 的 4 个 内 悉数 组 的 数量 ， 所 以 输出 如 图 6-16 所 示 。 
(3) echo count($roomtypesinfo,1) 这 一 语句 中 , count0 函 数 设置 了 一 个 模式 (mod) 为 整数 “1”。 
这 个 模式 (mod) 设置 为 整数 “1” 的 意义 是 ，count 统计 的 时 候 要 对 数组 内 部 所 有 的 内 堪 数 组 进行 
循环 查询 , 所 以 最 终 的 结果 是 所 有 内 堪 数 组 的 个 数 加 上 内 堪 数 组 内 元 素 的 个 数 , 即 4 个 内 嵌 数 组 加 
上 12 个 数组 元 素 ， 为 16。 
使 用 array_count_values() 函 数 对 数组 内 的 元 素 值 进行 统计 , 并 且 返 回 一 个 以 函数 值 为 “ 键 值 ”、 
以 函数 值 个 数 为 “元 素 值 ”的 数组 。 
下 面 通过 实例 介绍 如 何 使 用 array_count_values0 函 数 统计 数组 的 元 素 值 个 数 。 
【 例 6.16】〔 实 例文 件 ， ch06\6.16.php) 
<?php 


$prices_per_day = array(' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, ' 四 床 房 '=> 
198, 'VIP 套房 '=> 368); 


print rl(array_ count values($prices per day)); 
人 


运行 结果 如 图 6-17 所 示 。 
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用 array_count_values 函 数 统计 数组 内 元 素 值 。 


Array ( [298] =》 1 [268] => 1 [198] => 2 [358] => 1 ) 








图 6-17 程序 运行 结果 
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【案例 分 析 】: 


(1) 其 中 ， 数 组 $prices_per_day 为 一 个 联合 数组 ， 通 过 array_count values($prices_per_day) 
统计 数组 内 元 素 值 的 个 数 和 分 布 ， 然 后 以 键 值 和 值 的 形式 返回 一 个 数组 ， 如 图 6-17 所 示 。 元 素 值 
为 198 的 元 素 有 两 个 ， 虽 然 它们 的 键 值 完全 不 同 。 

(2) array_count valuesO 只 能 用 于 一 维 数组 ， 因 为 它 不 能 把 内 嵌 的 数组 当 作 元 素 进行 统计 。 


6.11 ”删除 数组 中 的 重复 元 素 


可 使 用 array_unique() 函 数 实现 数组 中 元 素 的 唯一 性 ， 也 就 是 去 掉 数组 中 重复 的 元 素 。 不 管 是 
数字 索引 数组 还 是 联合 索引 数组 , 都 是 以 元 素 值 为 准 。array_unique() 函 数 返回 具有 唯一 性 元 素 值 的 
数组 。 

下 面 通过 实例 介绍 如 何 使 用 array_unique() 函 数 去 掉 数组 中 重复 的 元 素 。 

【 例 6.17】〔 实 例文 件 ，ch06\6.17.php) 
<?php 
$prices_per_day = array (' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, ' 四 床 房 '=> 
198, 'VIP 套房 '=> 368); 
$prices_per_day2 =array(' 单 床 房 '=> 298,' 标 准 间 '=> 268, ' 四 床 房 '=> 198, ' 三 床 房 '=> 
198, 'VIP 套房 '=> 368); 
print rl(array unique ($prices per day)); 
print rl(array unique ($prices per day2)); 
> 


了 结果 如 图 6-18 所 示 。 








PERFECT 恒 
VIA 工具 (相反 (站 下 


用 array_unique 函 教 清除 教 组 内 重复 元 素 值 。 


如 ray ( [总 条 局] =》 239 [村 从 加 ] =》 258 上 后 永 忆 ] -> 3 增 Ms = 368 ) 
hrray 〈 [ 单 床 启 ] =》298 [标准 间 ] => 268 [四 床 肩 ] =; [V1p 套 贿 ] => 368 ) 














R100% ~ 





图 6-18 程序 运行 结果 
【案例 分 析 】 


其 中 , 数组 $prices_per_day 为 一 个 联合 索引 数组 , 通过 array_unique ($prices_per_day) 去 除 重复 
的 元 素 值 。array_unique () 函 数 去 除 重 复 的 值 就 是 去 除 第 二 个 出 现 的 相同 值 。 所 以 ， 由 于 
$prices_per day 与 $prices_per day2 数组 中 ， 键 值 为 “三 床 房 ”和 键 值 为 “四 床 方 ” 的 198 元 素 的 
位 置 正好 相反 ， 所 以 对 两 次 输出 所 保留 的 值 也 正好 相反 ， 如 图 6-18 所 示 。 


6.12 ”调换 数组 中 的 键 值 和 元 素 值 
可 使 用 array_flip() 函 数 调换 数组 中 的 键 值 和 元 素 值 。 
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下 面 通过 实例 介绍 如 何 使 用 array_flip0 函 数 调换 数组 中 的 键 值 和 元 素 值 ， 具 体 方法 如 下 。 
【 例 6.18】 《实例 文件 ，ch06\6.18.php) 
<?php 
$prices_per_ day = array (' 单 床 房 '=> 298, ' 标 准 间 '=> 268, ' 三 床 房 '=> 198, ' 四 床 房 '=> 
198, 'VIP 套房 '=> 368); 
print r(array flip ($prices per day)); 
> 


运行 结果 如 图 6-19 所 示 。 





【< 并 DB o/calhost p ~ BO x [Biceanor 
Er IE 一 ER 

















用 array_flip 函 数 调换 数组 内 键 值 和 元 素 值 。 


Array 【 [298] =》 单 床 房 [268] => 标 准则 [198] = 四 床 局 [368] =》 YIP 认 后 ) 





图 6-19 程序 运行 结果 


其 中 数组 $prices_per_day 为 一 个 联合 索引 数组 , 通过 array_flip ($prices_per_day) 调 换 联 合 索引 
数组 的 键 值 和 元 素 值 ,并且 加 以 返回 。 但 有 意思 的 是 Sprices_per day 是 一 个 拥有 重复 元 素 值 的 数组 ， 
且 这 两 个 重复 元 素 值 的 “ 键 名 ”是 不 同 的 。array_flip () 逐 个 调换 每 个 数组 元 素 的 键 值 和 元 素 值 。 而 
如 果 原 来 的 元 素 值 变 为 键 名 以 后 ， 就 有 两 个 原先 为 键 名 , 现在 调换 为 元 素 值 的 数值 与 之 对 应 。 调换 
后 , array_flip () 等 于 对 原来 的 元 素 值 ( 即 现在 的 键 名 ) 赋值 。 当 array_flip () 再 次 调换 到 原来 相同 的 、 
现在 为 键 名 的 值 时 ， 相当 于 对 同一 个 键 名 再 次 赋值 ， 则 头 一 个 调换 时 的 赋值 将 会 被 覆盖 ,显示 的 是 
第 二 次 的 赋值 。 


6.13 ”实战 演练 一 一 数组 的 序列 化 


数组 的 序列 化 〈serialize) 用 来 将 数组 的 数据 转换 为 字符 串 ， 以 方便 传递 和 数据 库 的 存储 。 而 
与 之 相对 应 的 操作 就 是 反 序列 化 (unserialize》， 把 字符 串 数据 转换 为 数组 加 以 使 用 。 

下 面 通过 实例 介绍 serialize0 函 数 和 unserialize() 函 数 。 
【 例 6.19】 《实例 文件 ，ch06\6.19.php) 

<?php 

$arr = array(' 王 小 明 '，,' 李 丽 丽 ', "方芳 芳 ',' 刘 小 帅 ',' 张 大勇 ',' 张 明明 ' ) ; 

$str = serialize($arr); 

Gcho Satr "<br /><br /2" 

$new arr = unserialize ($str); 

print r($new arr); 

> 


运行 结果 如 图 6-20 所 示 。 
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| tp//ocalhost P - BO x | @localhost x| i 
文件 (有 闹 演 日 。 坦 看 (V)。 收 生 夫 内 工具 (帮助 H) 














a:6: 皇 王小明 "1:1;s:6:" 李 丽 丽 "112:s:6:“ 方 芳 芳 ".13;s:6:7 刘 小 山 “i:4.s:6: 张 
大 勇 ”;i:5;s:6:“ 张 明明 ”;】 


Array ( [0] =》 王小明 [1] => 李 丽 丽 [2] =》 方芳 芳 [3] => 刘 小 帅 [4] => 张大 勇 [5] => 
张 明 明 ) 











图 6-20 程序 运行 结果 


erialize() 和 unserialize0 两 个 函数 的 使 用 比较 简单 , 但 是 通过 这 样 的 方法 对 数组 数据 的 存储 和 传 
递 将 会 十 分 方便 。 比 如 ， 可 以 直接 把 序列 化 之 后 的 数组 数据 存放 在 数据 库 的 某 个 字段 中 。 在 使 用 时 
再 通过 反 序 列 化 进行 处 理 。 


6.14 ”高 手 私房 菜 


技巧 1: 数组 的 合并 与 联合 的 区 别 是 什么 ? 

对 数组 的 合并 使 用 array_merge() 函 数 。 两 个 数组 的 元 素 会 合并 为 一 个 数组 的 元 素 。 而 数组 的 
联合 ， 是 指 两 个 一 维 数组 ， 一 个 作为 关键 字 ， 一 个 作为 数组 元 素 值 ， 而 联合 成 为 一 个 新 的 联合 索引 
数组 。 

技巧 2: 如 何 快 速 清空 数组 ? 

在 PHP 中 ， 快 速 清空 数组 的 方法 如 下 。 


arr=array () // 理 解 为 重新 给 变量 赋 一 个 空 的 数组 。 
unset ($arr) // 这 才 是 真正 意义 上 的 释放 ， 将 资源 完全 释放 。 


6.15 经典 习题 


(1) 制作 一 个 包含 常量 数组 和 变量 数组 的 例子 ， 并 分 析 它 们 的 区 别 。 
(2) 制作 一 个 包含 一 维 数组 和 多 维 数组 的 例子 。 

(3) 制作 一 个 包含 遍历 数组 的 例子 。 

(4) 制作 一 个 包含 数组 排序 的 例子 。 

(5) 制作 一 个 包含 字符 串 和 数组 相互 转换 的 例子 。 


we 
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时 间 和 日 期 对 于 很 多 应 用 来 说 都 是 十 分 敏感 的 ， 程 序 中 很 多 情况 下 都 是 依靠 时 间 和 日 期 才能 
作出 判断 从 而 完成 操作 的 ， 例 如 在 酒店 商务 网 站 中 查看 最 新 房价 的 情况 ， 这 和 时 间 是 密 不 可 分 的 。 
本 章 将 介绍 日 期 和 时 间 的 获得 及 格式 化 方面 的 内 容 。 

本 章 学 习 目标 

了 解 系统 时 间 的 设置 方法 

熟悉 UNIX 时 间 堆 的 概念 

掌握 获取 当前 时 间 惟 的 方法 
掌握 获取 当前 日 期 和 时 间 的 方法 
掌握 使 用 时 间 鹤 获取 日 期 的 方法 
掌握 检验 日 期 有 效 性 的 方法 
掌握 输出 格式 化 日 期 的 方法 
掌握 比较 时 间 大 小 的 方法 

掌握 实现 倒计时 功能 的 方法 


7.1 系统 时 区 设置 


这 里 的 系统 时 区 是 指 运行 PHP 的 系统 环境 。 常 见 的 有 Windows 系统 和 UNIX-like (类 UNIX) 
系统 ， 对 于 时 区 的 设置 关系 到 运行 应 用 的 时 间 准 确 性 。 


7.1.1 时 区 划分 


时 区 的 划分 是 一 个 地 理 概念 。 从 本 初子 午 线 开 始 向 东 和 向 西 各 有 12 个 时 区 。 比 如 北京 时 间 是 
东 八 区 ， 美 国 太平 洋 时 间 是 西 人 区 。 在 Windows 系统 里 这 个 操作 比较 简单 。 在 时 间 时 区 的 控制 面 
板 中 设置 就 行 了 。 在 Linux 这 样 的 UNIX-like 系统 中 需要 使 用 命令 对 时 区 进行 设置 。 


7.1.2 时 区 设置 


PHP 中 日 期 和 时 间 的 默认 设置 是 GMT 格林 尼 治 时 间 。 在 使 用 时 间 日 期 功能 之 前 , 需要 对 时 区 
进行 设置 。 在 中 国 ， 就 需要 使 用 “Asia/Hong Kong” 香 港 时 间 。 

时 区 的 设置 方法 主要 有 以 下 两 种 。 

(1) 修改 php.ini 文件 的 设置 。 找 到 “;date.timezone=” 选 项 ， 将 其 值 修改 为 date.timezone = 
Asia/Hong_ Kong， 这样 系 统 默认 时 间 为 东 八 区 的 时 间 。 

(2) 在 应 用 程序 中 ， 直 接 使 用 函数 date_default timezone set() 把 时 区 设 为 date_default_ 
timezone_set("Asia/Hong Kong")。 此 种 方法 比较 灵活 。 

设置 完成 后 ，date() 函 数 便 可 以 正常 使 用 ， 不 会 出 现时 差 的 问题 。 








Xl 
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7.2 PHP 日 期 和 时 间 函 数 
本 节 开 始 学 习 PHP 常用 日 期 和 时 间 函 数 的 使 用 方法 和 技巧 。 
7.2.1 关于 UNIX 时 间 戳 


在 很 多 情况 下 ， 程 序 需要 对 日 期 进行 比较 、 运 算 等 操作 。 如 果 按 照 人 们 日 常 的 计算 方法 ， 很 
容易 知道 6 月 5 号 和 6 月 8 号 相差 几 天 。 然 页， 人们 日常 对 日 期 的 书写 方式 是 2012-3-8 或 2012 年 
3 月 8 日 星期 五 .这 让 程序 如 何 运算 呢 ? 对 于 整 型 数据 的 数学 运算 好 像 对 这 样 的 描述 并 不 容易 处 理 。 
如 果 想 知道 3 月 8 号 和 4 月 23 号 相差 几 天 ， 则 需要 把 月 先 转换 为 30 天 或 31 天 ， 再 对 剩余 天 数 进 
行 加 减 。 这 是 一 个 很 麻烦 的 过 程 。 

如 果 时 间或 者 日 期 是 一 个 连贯 的 整数 ， 这 样 处 理 起 来 就 很 方便 了 。 幸 运 的 是 ， 系 统 的 时 间 正 
是 以 这 种 方式 存储 的 ， 这 种 方式 就 是 时 间 惟 ， 也 称 为 UNIX 时 间 鹤 。UNIX 系统 和 UNIX-like 系统 
把 当下 的 时 间 存 储 为 32 位 的 整数 ， 这 个 整数 的 单位 是 秒 ， 而 这 个 整数 的 开始 时 间 为 格林 尼 治 时 间 

(GMT) 的 1970 年 1 月 1 日 的 零点 整 。 换 句 话说 ， 就 是 现在 的 时 间 是 GMT1970 年 1 月 1 日 的 零 
点 整 到 现在 的 秒 数 。 

由 于 每 一 秒 的 时 间 都 是 确定 的 ， 这 个 整数 就 像 章 戳 一 样 不 可 改变 ， 所 以 就 称 为 UNIX 时 间 戳 。 

时 间 鹤 在 Windows 系统 下 也 是 成 立 的 ， 但 是 与 UNIX 系统 下 不 同 的 是 ，Windows 系统 下 的 时 
间 鹤 只 能 为 正 整 数 不 能 为 负 值 。 所 以 想 用 时 间 鹤 表示 1970 年 1 月 1 号 以 前 的 时 间 是 不 行 的 。 

PHP 则 完全 采用 了 UNIX 时 间 鹤 ,所 以 不 管 PHP 在 哪个 系统 下 运行 都 可 以 使 用 UNIX 时 间 戳 。 


7.2.2 ”获取 当前 时 间 戳 


获得 当前 时 间 的 UNIX 时 间 蕉 , 以 用 于 得 到 当前 时 间 。 要 完成 此 操作 直接 使 用 time() 函 数 即 可 。 
time() 函 数 不 需 要 任何 参数 ， 直 接 返 回 当前 日 期 和 时 间 。 
【 例 7.1】《〈 实 例文 件 ， ch07\7.1.php) 






































<?php 
$t1 =time(); // 获 取 当 前 时 间 截 
echo "当前 时 间 鹤 为 :".$t1; ”// 输 出 当前 时 间 截 
2 
运行 结果 如 图 7-1 所 示 。 
WO htpi/locs B 只 © | Emmaa 
文件 (久久 () 于 看 (V) 收藏 夫 A) 工具 (T) 帮助 H) 
当前 时 间 愉 为 : 1465275514 
图 7-1 程序 运行 结果 
【案例 分 析 】: 


(1) 图 中 的 数字 1465275514 表示 从 1970 年 1 月 1 日 0 点 0 分 0 秒 到 本 程序 执行 时 间隔 的 秒 
数 。 
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(2) 如 果 每 隔 一 段 时 间 刷新 一 次 页 面 ， 获 取 的 时 间 截 的 值 将 会 增加 。 这 个 数字 会 一 直 不 断 变 
大 ， 即 每 过 1 秒 ， 此 值 就 会 加 1。 
7.2.3 获取 当前 日 期 和 时 间 


可 使 用 date0) 函 数 返回 当前 日 期 ， 如 果 在 date() 函 数 中 使 用 参数 U 则 返回 当前 时 间 的 UNIX 时 
间 锥 。 如 果 使 用 参数 d 则 直接 返回 当前 月 份 的 01~31 号 的 两 位 数 日 期 。 
然而 ，date() 函 数 有 很 多 的 参数 ， 具 体 含义 如 表 7-1 所 示 。 


表 7-1 date() 函 数 的 参数 及 其 含义 





















































4 参数 含义 

a 大 写 AM 或 PM 

a [oraimHa |P |Mon 到 sun 的 简写 星期 

。 无 此 参数 

f 月 份 的 全 拼 单词 

g 24 小 时 格式 的 小 时 数 (0 到 23) 

h | 2 小 时 格式 的 小 时 数 (01 到 12》 | 中 | 24 小 时 格式 的 小 时 数 00 到 23) 

i 060) | | paytignt 

j 无 此 参数 

有 一 周 中 天 数 的 全 拼 Leap year 

m || 月份 (从 01 到 12) |M | 三 个 字母 的 月 份 简写 (从 Jan 到 Dec) 
n 无 此 参数 

o | 无 上 允 数 [0 | 与 格林 尼 治 时 间 相差 的 时 间 

s |[ 么 数 ( 从 00 到 59) |[s | 天 数 的 序数 表达 (st nd rd tt 

1 区 从 

N 当前 的 Unix 时 间 堆 

w 数字 表示 的 周 天 (从 0-Sunday 到 6-Saturday) ISO8601 标准 的 一 年 中 的 周 数 

y 四 位 数 的 公元 纪年 《从 1901 到 2038) 
z 以 秒表 现 的 时 区 《从 -43200 到 50400) 





7.2.4 ”使 用 时 间 戳 获取 日 期 信息 
如 果 相应 的 时 间 戳 已 经 存储 在 数据 库 中 ， 程 序 需 要 把 时 间 戳 转化 为 可 读 的 日 期 和 和 时间， 才能 
满足 应 用 的 需要 。PHP 中 提供 了 data0 和 getdate() 等 函数 来 实现 从 时 间 鹤 到 通用 时 间 的 转换 。 
1. data() 函 数 
data() 函 数 主 要 是 将 一 个 UNIX 时 间 戳 转化 为 指定 的 时 间 / 日 期 格式 。 该 函数 的 格式 如 下 。 
srting data (string format [时 间 截 整数 ] ) 
此 函数 将 会 返回 一 个 字符 串 。 该 字符 串 就 是 一 个 指定 格式 的 日 期 时 间 ， 其 中 format 是 一 个 字 


符 串 ， 用 来 指定 输出 的 时 间 格 式 。 时 间 戳 整数 可 以 为 空 ,如 果 为 空 ， 则 表示 为 当前 时 间 的 UNIX 时 
间 戳 。 
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format 参数 由 指定 的 字符 构成 ， 具 体 字 符 的 含义 如 表 7-2 所 示 。 


表 7-2 format 参数 及 含义 

format 字符 语义 
a am 或 pm 
A AM 或 PM 
几 日 ， 两 位 数字 ， 若 不 足 两 位 则 前 面 补 零 ， 例 如 01 至 31 
星期 几 ， 三 个 英文 字母 ， 例 如 : Fri 
月 份 ， 英 文 全 名 ， 例 如 : January 

小 时 制 的 小 时 ， 例 如 : 01 至 12 

小 时 制 的 小 时 ， 例 如 : 00 至 23 

小 时 制 的 小 时 ， 不 足 二 位 不 补 零 ， 例 如 :1 至 12 

小 时 制 的 小 时 ， 不 足 二 位 不 补 零 ， 例 如 :0 至 23 
分 钟 。 例 如 : 00 至 59 























下 面 通过 实例 来 理解 format 字符 的 使 用 方法 。 
【 例 7.2】〔 实 例文 件 ，ch07\7.2.php) 


<?php date default timezone set ("PRC"); 
// 定 义 一 个 当前 时 间 的 变量 
Stt =time(); 
echo "目前 的 时 间 为 : <br />"; 
// 使 用 不 同 的 格式 化 字符 测试 输出 效果 
echo date ("Y 年 m 月 d 日 [1]H 点 分 s 秒 ",$tt)."<br />"; 
echo date ("y-m-d h:i:s a",$tt)."<br />"; 
Seho dateo ("Y=M-D ET: Aumet) rbr /2 
echo date ("F,d,y 1",$tt)." <br />"; 
echo Gate ("Y=M-D HI:S" Stt) oe" <br /> 


> 


运行 结果 如 图 7-2 所 示 。 





时 间 和 日 期 第 7 章 












| eveconenvcror P - © | sas 
文人 急病 日 。 坦 霖 上 站 雪 A， 工具 项 二 人 H) 
目前 的 时 间 为 : 

2016 年 06 月 19 日 [Sunday]17 点 29 分 34 秒 
16-06-19 05:29:34 pm 

2016-Jun-Sun 17:0:th PM 

June, 19, 16 Sunday 

2016-Jun-Sun 17:0:th 














图 7-2 程序 运行 结果 
【案例 分 析 】: 


(1) date_default_timezone_set("PRC") 语 句 的 作用 是 设置 默认 时 区 为 北京 时 间 。 如 果 不 设 置 将 
会 显示 安全 和 警告 信息 。 

(2) 格式 化 字符 的 使 用 方法 非常 灵活 ， 只 要 设置 字符 串 中 包含 的 字符 ，date() 函 数 就 能 将 字符 
串 蔡 换 成 指定 的 时 间 日 期 信息 。 利 用 上 面 的 函数 可 以 随意 输出 自己 需要 的 日 期 。 


2. getdate() 函 数 
getdate() 函 数 用 于 获取 详细 的 时 间 信息 ， 函 数 的 格式 如 下 : 
array getdate 〔 时 间 戳 整数 ) 


getdate() 函 数 返 回 一 个 数组 ， 包 含 日 期 和 时 间 的 各 个 部 分 。 如 果 它 的 参数 时 间 蕉 整数 为 空 ， 则 
表示 直接 获取 当前 时 间 蕉 。 

下 面 通过 实例 说 明 此 函数 的 使 用 方法 和 技巧 。 

【 例 7.3】〔 实 例文 件 ，ch07\7.3.php) 


<?php date default timezone set ("PRC"); 
// 定 义 一 个 时 间 的 变量 
Stm ="2012-08-08 08:08:08"; 
echo "时 间 为 : "。 S$tm. "<br />"; 
// 将 格式 转化 为 Unix 时 间 截 
StP =strtotime (Stm) ; 
echo "此 时 间 的 Unix 时 间 蕉 为 : ".$tp. "<br />"; 
Sarl =getdate(StP) ; 
echo "年 为 : "。 $arl["year"]."<br />"; 
Seho "Har monml mb/ 
echo "日 为 : ". $arl["mday"]."<br />"; 
echo "点 为 : "。 $arl["hours"]."<br />"; 
echo "分 为 : ". $arl["minutes"]."<br />"; 
echo " 秒 为 : ". $arl["seconds"]."<br />"; 


2 


运行 结果 如 图 7-3 所 示 。 
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[< 周 辰 hapyWiocalhox P - 虽 c x | 伟 z 了 当 的 时 间 可 x nm 
文 #。 转 各 日 ”查看 M 收藏 大 (A) 工具 (T) 攻 动 H) 























时 间 为 ，2012-08-08 08:08:08 
此 时 间 的 Unix 时 间 截 为 ，1344384488 
年 为 ，2012 


二 
起 尝 斗 学 
momm 











7.2.5 检验 日 期 的 有 效 性 


使 用 用 户 输入 的 时 间 数 据 时 ， 会 由 于 用 户 输入 的 数据 不 规范 而 导致 程序 运行 出 错 。 为 了 检查 
时 间 的 合法 有 效 性 ， 需 要 使 用 checkdate() 函 数 对 输入 日 期 进行 检测 。 它 的 格式 为 : 
checkdate (月 份 ， 日 期 年份) 


此 函数 检查 的 项 目 是 ,年 份 是 否 在 0~32767 之 间 ， 月 份 是 否 在 1~12 之 间 , 日 期 是 否 在 相应 的 
月 份 的 天 数 内 。 下 面 通过 实例 来 讲述 如 何 检查 日 期 的 有 效 性 。 
【 例 7.4】〈 实 例文 件 : ch07\7.4.php) 


<?php 
if(checkdate(2,31,2016)){ 
echo "这 不 可 能 。"; 
}else{ 
echo "2 月 没有 31 号 。"; 








国 | 四 - Gre/oc BP- © | locahost 
文件 朋 ”要 弓 FE) 合 硅 (V) 收 守 大 (A) 工具 (m 。 其 芍 IH) 
2 月 没有 31 号 - 














图 7-4 程序 运行 结果 
7.2.6 ”输出 格式 化 时 间 戳 的 日 期 和 时 间 


可 使 用 strftime0) 把 时 间 戳 格式 化 为 日 期 和 时 间 。 它 的 格式 如 下 : 
strftime (格式 ， 时 间 蕉 ) 














Be 


其 中 “格式 ”决定 了 如 何 把 其 后 面 的 时 间 蕉 格 式 化 并 且 输 出 。 如 果 时 间 蕉 为 空 ， 则 系统 当前 
时 间 戳 将 会 被 使 用 。 
关于 “格式 ”的 代码 ， 如 表 7-3 所 示 。 


%116 
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表 7-3 “格式 ”的 代码 描述 
代码 描述 代码 ”描述 
%a 周 日 期 〈 缩 简 ) 














%b 或 %h | 月 份 〈 缩 简 ) 


%e 









标准 格式 的 日 期 和 时 间 















月 日 期 (从 01 到 31) 


%d 








%B 月 份 
%D 日 期 的 缩 简 格式 ‘mm/dd/yy) 


A (从 0 根据 周 数 的 年 份 (4 个 数字 ) 









%g 根据 周 数 的 年 份 (2 个 数字 ) 小 时 数 〈 从 00 | 小 时 数 ( 从 00 到 23) | 23) 
%i 一 年 中 的 天 数 〔 从 001 到 366) 小 时 数 (从 1 到 12) 
hm 月 份 (从 01 到 12) 分 钟 (从 00 到 59) 



















%n 新 一 行 〈( 同 m) 
%p am 或 pm 
%r 时 间 使 用 am 或 pm 表示 
Tab ( 同 \t) 





时 间 使 用 24 小 时 制 表示 








时 间 使 用 hh:ss:mm 格式 表示 


%t 








%u 周 天 数 (从 1-Monday 到 7-Sunday) 


%w 周 天 数 (从 0-Sunday 到 6-Saturday) 为 第 一 周 ) 


Wx 标准 格式 日 期 (无 时 间 》 
%y 年 份 (2 个 字符 ) 
%z 和 %Z | 时 区 


下 面 通过 实例 介绍 该 函数 的 用 法 。 
【 例 7.5】〔 实 例文 件 ，ch07\7.5.php) 








<?php 
date default timezone set ("PRC"); 
echo (strftime ("%b %d %Y %X", mktime (20,0,0,12,31,98))); 
echo(gmstrftime("%b %d %Y %X", mktime(20,0,0,12,31,98))); 
// 输 出 当前 日 期 、 时 间 和 时 区 
echo (gmstrftime("It is %a on %b %d, %Y, %X time zone: %2",time())); 


2>: 


运行 结果 如 图 7-5 所 示 。 











| 8 @ mohocalhosvcto7 是 口 -| 合生 st 二 化 时 fy 间 x| | 


文件 月 声 二 (EF) 到 者 (V) 收 到 天 (A) 工具 (T) 大 却 (H) 





Dec 31 1998 20:00:00Dec 31 1998 12:00:00It is Tue on Jun 07, 
2016，04:53:26 time zone: 中 国标 准时 间 





图 7-5 程序 运行 结果 


秒 (从 00 到 59) 








a 中 的 周 数 〈 从 第 一 周 的 第 一 个 星期 天 开 
下 (以 至 少 剩余 四 天 的 这 一 周 开始 


-年 中 的 周 数 〈 从 第 一 周 的 第 一 个 星期 一 开 
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7.2.7 显示 本 地 化 的 日 期 和 时 间 


由 于 世界 上 有 不 同 的 显示 习惯 和 规范 ， 所 以 日 期 和 时 间 也 会 根据 不 同 的 地 区 显示 为 不 同 的 形 
式 。 这 就 是 日 期 和 时 间 的 本 地 化 显示 。 

实现 此 操作 需要 使 用 到 setlocale0 和 strftime() 两 个 函数 。 后 者 已 经 介绍 过 。 

可 使 用 setlocale0 函 数 来 改变 PHP 的 本 地 化 默认 值 ， 实 现 本 地 化 的 设置 。 它 的 格式 为 : 

setlocale (目录 ， 本 地 化 值 


(1) “本 地 化 值 ”是 一 个 字符 串 ， 它 有 一 个 标准 格式 : language_COUNTRY .chareacterset。 比 
如 ， 想 把 本 地 化 设 为 美国 ， 按 照 此 格式 为 en_US.utf8; 如 果 想 把 本 地 化 设 为 英国 ， 按 照 此 格式 为 
en_GB.utf8; 如 果 想 把 本 地 化 设 为 中 国 ， 且 为 简体 中 文 ， 按 照 此 格式 为 zh_CN.gb2312， 或 者 
zh_CN.utf8。 

(2) “目录 ”是 指 6 个 不 同 的 本 地 化 目录 ， 如 表 74 所 示 。 


表 7-4 本 地 化 目录 

















目录 

LC ALL 为 后 面 其 他 的 目录 设 定 本 地 化 规则 的 目录 
字符 趾 对 比 目 录 

字母 划 类 和 规则 


货币 表示 规则 
数字 表示 规则 
日 期 和 时 间 表 示 规则 





由 于 这 里 要 对 日 期 时 间 进 行 本 地 话 设置 ， 需 要 使 用 到 的 目录 是 LC_TIME。 下 面 通过 实例 对 日 
期 时 间 本 地 化 进行 讲解 。 
【 例 7.6】 (实例 文件 :ch07\7.6.php) 


<?php 
date default timezone set ("PRC"); 
date default timezone set ("Asia/Hong_Kong"); // 设 置 时 区 为 中 国 时 区 
setlocale (LC _TIME, "zh CN.gb2312"); // 设 置 时 间 的 本 地 化 显示 方式 
echo strftime("%2z"); // 输 出 所 在 的 时 区 

2 


运行 结果 如 图 7-6 所 示 。 





(Oe ee os ox]S snc | 


文件 (F) ”六 往 {E) 豆 乔 (V) 收藏 夫 (A) 工具 人 T 者 动 (H) 




















中 国标 准时 间 








图 7-6 程序 运行 结果 





时 间 和 日 期 第 7 章 





【案例 分 析 】: 


(1) 其 中 ，date_default timezone_set("Asia/Hong Kong") 设 定时 区 为 中 国 时 区 。 
(2) setlocale(LC_TIME, "zh_CN.gb2312") 设 置 时间 的 本 地 化 显示 方式 为 简体 中 文 方式 。 


(3) strftime("%z") 返 回 所 在 时 区 ， 其 在 页 面 中 显示 为 简体 中 文 。 
7.2.8 ”将 日 期 和 时 间 解 析 为 UNIX 时 间 截 


使 用 给 定 的 日 期 和 时 间 ， 操 作 mktime() 函 数 可 以 生成 相应 的 UNIX 时 间 戳 。 它 的 格式 为 : 


mktime (小 时 ,分钟 ， 秒 ， 月 份 ， 日 期 ， 年 份 ) 


把 相应 的 时 间 和 日 期 的 部 分 输入 相应 位 置 的 参数 ， 即 可 得 到 相应 的 时 间 戳 。 


绍 此 函数 的 应 用 方法 和 技巧 。 
【 例 7.7】《〈 实 例文 件 : ch07\7.7.php) 
<?php 
$timestamp = mktime(0,0,0,3,31,2012); // 获 取 指 定 日 期 的 时 间 蕉 
echo $timestamp; // 输 出 时 间 截 


2 


运行 结果 如 图 7-7 所 示 。 








hapyjlocalhos P - BO X | localhost 


文件 站 ”顽强 (E) 查看 (V) 收 荐 夫 (A) 工具 (T) 帮 动 (H) 





1333152000 








图 7-7 程序 运行 结果 
其 中 mktime(0,0,0,3,31,2012) 使 用 的 时 间 是 2012 年 3 月 31 号 0 点 整 。 
7.2.9 日 期 和 时 间 在 PHP 和 MySQL 数据 格式 之 间 的 转换 


下 面 通过 实例 介 


日 期 和 时 间 在 MySQL 中 是 按照 ISO8601 格式 存储 的 。 这 种 格式 要 求 以 年 份 打头 ， 如 
2012-03-08。 从 MySQL 读 取 的 默认 格式 也 是 这 种 格式 。 这 种 格式 中 国人 是 比较 熟悉 的 。 在 中 文 应 


用 中 ， 几 乎 可 以 不 用 转换 ， 就 直接 使 用 这 种 格式 。 








但 是 , 在 西方 的 表达 方法 中 经 常 把 年 份 放 在 月 份 和 日 期 的 后 面 ， 如 March 08, 2012。 所 以 , 在 
接触 到 国际 ， 特 别 是 符合 英语 使 用 习惯 的 项 目 时 ， 需 要 把 ISO8601 格式 的 日 期 时 间 加 以 合适 的 转 


换 。 


有 意思 的 是 ， 为 了 解决 这 个 英文 使 用 习惯 和 ISO8601 格式 冲突 的 问题 MySQL 提供 了 把 英文 
使 用 习惯 的 日 期 时 间 转 换 为 符合 ISO8601 标准 的 两 个 函数 ， 即 DATE FOMAT() 和 
UNIX_TIMESTAMP()。 这 两 个 函数 在 SQL 语言 中 使 用 ， 它 们 的 具体 用 法 将 在 介绍 MySQL 的 部 分 


详 述 。 
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7.3 ”实战 演练 1 一 一 比较 两 个 时 间 的 大 小 


比较 两 个 时 间 的 大 小 时 ， 如 果 通 过 一 定形 式 的 时 间 和 日 期 进行 比较 ， 或 者 不 同 格式 的 时 间 和 
日 期 进行 比较 ， 都 不 方便 。 最 方便 的 方法 是 把 所 有 格式 的 时 间 都 转换 为 时 间 戳 ， 然 后 比较 时 间 戳 的 
大 小 。 

下 面 通过 实例 来 比较 两 个 时 间 的 大 小 。 

【 例 7.8】《〈 实 例文 件 : ch07\7.8.php) 

<?php 

$timestampA = mktime (0,0,0,3,31,2015); // 获 取 指 定 日 期 的 时 间 戳 

$timestampB = mktime (0,0,0,1,31,2016); 

if($timestampA > $timestampB ) 1{ // 比 较 两 个 时 间 截 的 大 小 

echo "2015 年 三 月 的 时 间 蕉 数值 大 于 2016 年 一 月 的 。 "7 

}elseif( $timestampA < $timestampB ){ 

echo "2015 年 三 月 的 时 间 蕉 数值 小 于 2016 年 一 月 的 。"; 
}elsei{ 


echo "两 个 时 间 相 同 。" 7 
} 


和 


运行 结果 如 图 7-8 所 示 。 





号 | ner localhostcho7 户 ~ 人 | 总 localhost 


文人 (有 入 和 日 ”下 看 MI) 多 家 人 工具 (T) 丙 动 (H) 
2015 年 三 月 的 时 间 稚 数值 小 于 2016 年 一 月 的 。 





图 7-8 程序 运行 结果 


7.4 ”实战 演练 2 一 一 实现 倒计时 功能 


对 于 未 来 的 时 间 点 实现 倒计时 ， 其 实 就 是 使 用 现在 的 当下 时 间 难 和 未 来 的 时 间 点 进行 比较 和 
运算 。 
下 面 通过 实例 来 介绍 如 何 实现 倒计时 功能 。 
【 例 7.9】〔 实 例文 件 ，ch07\7.9.php) 


<?php 
$timestampfuture = mktime (0,0,0,12,12,2016); // 获 取 指 定 日 期 的 时 间 截 
$timestampnow = time () // 获 取 当 前 日 期 的 时 间 戳 
$timecount = Stimestampfuture - $timestampnow;  // 获 取 倒 计时 的 时 间 差 
$days = round ($timecount/86400); // 获 取 天 数 
echo "今天 是 ".date('Y F d') ." ,距离 2016 年 12 月 12 号 的 时 间 惟 ， 还 有 ".$days." 天 。"; 
> 


运行 结果 如 图 7-9 所 示 。 
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今天 是 2016 June 07 ,距离 2016 年 12 月 12 号 的 时 间 歌 ， 还 有 188 天 - 





图 7-9 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 ，mktime(0) 不 带 任何 参数 ， 所 生成 的 时 间 戳 是 当前 时 间 的 时 间 戳 。 

(2) $timecount 是 现在 的 时 间 戳 距离 未 来 时 间 点 的 时 间 戳 的 秒 数 。 

(3) round($timecount/86400), 其 中 86400 为 一 天 的 秒 数 , Stimecount/86400 得 到 天 数 , round() 
函数 取 约 数 ， 得 到 天 数 。 


7.5 高 手 私房 菜 


技巧 1: 如 何 使 用 微 秒 ? 

有 些 时 候 ， 某 些 应 用 要 求 使 用 比 秒 更 小 的 时 间 单 位 来 表明 时 间 。 比 如 在 一 段 测 试 程序 运行 的 
程序 中 ， 可 能 要 使 用 到 微 秒 级 的 时 间 单 位 来 表明 时 间 。 这 时 只 需要 使 用 函数 microtime(true)， 如 下 
所 示 : 

<?php 

$timestamp = microtime (true); 


echo $timestamp; 
?> 


返回 的 结果 为 1315560215.7656。 时 间 戳 精确 到 小 数 点 后 4 位 。 

技巧 2: 定义 时 间 和 日 期 时 出 现 警告 怎么 办 ? 

在 运行 PHP 程序 时 ， 有 时 会 出 现 这 样 的 警告 : PHP Warning: date(): It is not safe to rely on the 
System's timezone settings。 出 现 上 述 警 告 是 因为 PHP 所 取 的 时 间 是 格林 尼 治 标准 时 间 ， 和 用 户 当 地 
的 时 间 会 有 出 入 ， 由 于 格林 威 治标 准时 间 和 北京 时 间 大 概 差 8 个 小 时 ， 所 以 会 弹出 和 警告。 可 以 使 用 
下 面 方法 中 的 任意 一 个 来 解决 。 

(1) 在 页 头 使 用 date_default timezone set() 设 置 默 认 时 区 为 北京 时 间 ， 即 <?php 
date_default_timezone_set("PRC"); 2> 即 可 ， 例 如 本 章 例 7.2 中 所 示 。 

(2) 在 php.ini 中 设置 date.timezone 的 值 为 PRC， 设 置 语句 为 date.timezone=PRC， 同 时 取消 
这 一 行 代码 的 注释 ， 即 去 掉 前 面 的 分 号 。 


7.6 经 典 习题 


(1) 制作 一 个 包含 获取 当前 时 间 戳 的 例子 。 
(2) 制作 一 个 输出 当前 时 间 和 日 期 的 例子 。 
(3) 制作 一 个 包含 比较 两 个 时 间 大 小 的 例子 。 
(4) 制作 一 个 实现 倒计时 功能 的 例子 。 


第 8 章 面向 对 象 编程 


面向 对 象 是 现在 编程 的 主流 技术 ，PHP 也 不 例外 。 面 向 对 象 objectoriented) 不同 于 面向 过 
程 (process-oriented) ， 它 用 类 、 对 象 、 关 系 、 属 性 等 一 系列 概念 来 提高 编程 的 效率 。 它 主要 的 特 
性 是 可 封装 性 、 可 继承 性 和 多 态 性 。 本 章 主要 讲述 面向 对 象 的 相关 知识 。 
本 章 学 习 目标 
@ 了 解 类 和 对 象 的 基本 概念 
熟悉 PHP 中 类 的 基本 操作 
掌握 构造 方法 和 析 构 方法 
掌握 访问 方法 
掌握 类 的 继承 
掌握 抽象 类 和 接口 的 使 用 方法 
掌握 面向 对 象 的 多 态 性 


8.1 类 和 对 象 的 介绍 


面向 对 象 编程 的 主要 优势 就 是 把 编程 的 重心 从 处 理 过 程 转移 到 了 对 现实 世界 实体 的 表达 。 这 
十 分 符合 人 们 的 思维 方式 。 

类 (classes) 和 对 象 (objects) 并 不 难 理解 。 试 想 一 下 , 在 日 常生 活 中 ， 自 然 人 对 事物 的 认识 ， 
一 般 是 由 看 到 的 、 感 受到 的 实体 〈 日 常生 活 中 的 吃 穿 住 用 ) 归纳 出 来 ， 或 者 抽象 出 它们 的 类 。 比 如 
当 看 到 楼 下 停 的 汽车 中 都 是 Polo 或 QQ 的 时 候 ， 人 们 自然 会 想到 ， 这 些 都 是 “两 厢 车 ”。 当 衣柜 
里 到 处 都 是 NIKE、addidas 的 时 候 ， 人 们 同样 会 想到 ， 这 些 都 是 “运动 装 ”。“ 两 厢 车 ”、“ 运 动 
装 ”就 是 抽象 出 的 类 。 这 就 是 人 们 认识 世界 的 过 程 。 

然而 程序 员 需 要 在 计算 机 的 世界 中 再 造 一 个 虚拟 的 “真实 世界 ”。 那 么 ， 在 这 里 程序 员 就 要 
像 “造物 主 ” 一 样 思考 ， 就 是 要 先 定 义 “ 类 ”， 然 后 再 由 “类 ”产生 一 个 个 “实体 ”， 也 就 是 一 个 
个 “对 象 ”。 

请 考虑 这 样 的 情况 。 过 年 的 时 候 ， 有 的 地 方 要 制作 “点 心 ”， 点 心 一 般 会 有 鱼 、 免 、 狗 等 生 
动 的 形状 。 而 这 些 不 同 的 形状 是 由 不 同 的 “模具 ”做 出 来 的 。 那 么 ， 在 这 里 鱼 、 免 、 狗 的 一 个 个 不 
同 的 点 心 就 是 实体 ， 最 先 刻 好 的 “模具 ”就 是 类 。 要 明白 ， 这 个 “模具 ” 指 的 是 被 刻 好 的 “形状 ”， 
而 不 是 制作 “模具 ”的 材料 。 如 果 你 能 像 造 物 主 一 样 用 意念 制作 出 一 个 个 点 心 ， 那么 ， 你 的 意念 世 

OOP 是 面向 对 象 编程 (Object-Oriented Programming〉 的 缩写 。 对 和 象 (object) 在 OOP 中 是 由 
属性 和 操作 组 成 的 。 属 性 〈attributes) 就 是 对 象 的 特性 或 与 对 象 关 联 的 变量 。 操 作 〈operation) 就 
是 对 象 中 的 方法 (method) 或 函数 (fbnction) 。 

由 于 OOP 中 最 为 重要 的 特性 之 一 就 是 可 封装 性 ， 所 以 对 对 象 内 部 数据 的 访问 ， 只 能 通过 对 象 
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的 “操作 ”来 完成 ， 这 也 被 称 为 对 象 的 “接口 ” (interfaces) 。 因 为 类 是 对 象 的 模板 ， 所 以 类 描述 
了 它 的 对 象 的 属性 和 方法 。 

另外 ， 面 向 对 象 编程 具有 3 大 特点 。 

(1) 封装 性 。 将 类 的 使 用 和 实现 分 开 管 理 ， 只 保留 类 的 接口 ， 这 样 开 发 人 员 就 不 用 知道 类 的 
实现 过 程 ， 只 需要 知道 如 何 使 用 类 即 可 ， 从 而 大 大 地 提高 了 开发 的 效率 。 

(2) 继承 性 . “继承 ”是 面向 对 象 软件 技术 中 的 一 个 概念 。 如 果 一 个 类 A 继承 自 另 一 个 类 B 
就 把 这 个 A 称 为 “B 的 子 类 ”， 而 把 B 称 为 “A 的 父 类 ”。 继 承 可 以 使 得 子 类 具有 父 类 的 各 种 属 
性 和 方法 ， 而 不 需要 再 次 编写 相同 的 代码 。 在 令 子 类 继承 父 类 的 同时 ， 可 以 重新 定义 某 些 属性 ， 并 
重 写 某 些 方法 ， 即 覆盖 父 类 的 原 有 属性 和 方法 ， 使 其 获得 与 父 类 不 同 的 功能 。 另 外， 还 可 以 为 子 类 
追加 新 的 属性 和 方法 。 继 承 可 以 实现 代码 的 可 重用 性 ， 简 化 对 象 和 类 的 创建 过 程 。 另 外 ，PHP 支 
持 单 继承 ， 也 就 是 一 个 子 类 只 能 有 一 个 父 类 。 

(3) 多 态 性 。 多 态 是 面向 对 象 程序 设计 的 重要 特征 之 一 ， 是 扩展 性 在 “继承 ”之 后 的 又 一 重 
大 表现 。 同 一 操作 作用 于 不 同 的 类 的 实例 ,将 产生 不 同 的 执行 结果 ， 即 不 同类 的 对 象 收 到 相同 的 消 
息 时 ， 得 到 不 同 的 结果 。 


8.2 PHP 中 类 的 操作 


类 是 面向 对 象 中 最 为 重要 的 概念 之 一 ， 是 面向 对 象 设 计 中 最 基本 的 组 成 模块 。 可 以 将 类 简单 
地 看 作 一 种 数据 结构 ， 在 类 中 的 数据 和 函数 称 为 类 的 成 员 。 


8.2.1 类 的 声明 
在 PHP 中 ， 声 明 类 的 关键 字 是 class， 声 明 格 式 如 下 : 


<?php 
权限 修饰 符 ”class 类 名 { 
类 的 内 容 ; 
} 
2 


其 中 权限 修饰 符 是 可 选项 ， 常 见 的 修饰 符 包 括 public、private 和 protected。 创 建 类 时 ， 可 以 省 
略 权限 修饰 符 ， 此 时 默认 的 修饰 符 为 public。public、private 和 protected 的 区 别 如 下 。 


(1) 一 般 情 况 下 ， 属 性 和 方法 的 默认 项 是 public， 这 意味 着 属性 和 方法 的 各 个 项 ， 从 类 的 内 
部 和 外 部 都 可 以 访问 。 

(2) 用 关键 字 private 声明 的 属性 和 方法 ， 则 只 能 从 类 的 内 部 访问 ， 也 就 是 ， 只 有 类 内 部 的 方 
法 才 可 以 访问 用 此 关键 字 声 明 的 类 的 属性 和 方法 。 

(3) 用 关键 字 protected 声明 的 属性 和 方法 ， 也 是 只 能 从 类 的 内 部 访问 ， 但 是 ， 通 过 “继承 ” 
而 产生 的 “ 子 类 ”， 也 是 可 以 访问 这 些 属 性 和 方法 的 。 

例如 ， 定 义 一 个 学 生 为 公共 类 ， 代 码 如 下 。 


Public class Student 
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// 类 的 内 容 
} 


8.2.2 成 员 属 性 


成 员 属性 是 指 在 类 中 声明 的 变量 。 在 类 中 可 以 声明 多 个 变量 ， 所 以 对 象 中 可 以 存在 多 个 成 员 
属性 ， 每 个 变量 将 存储 不 同 的 对 象 属性 信息 。 
例如 ， 以 下 定义 : 


Public class Student 
{ 

Public $name;// 类 的 成 员 属 性 
} 


其 中 成 员 属 性 必须 使 用 关键 词 进行 修饰 ， 常 见 的 关键 词 包 括 public、protected 和 private。 如 果 
没有 特定 的 意义 ， 仍 然 需 要 用 var 关键 词 修饰 。 另 外 ， 在 声明 成 员 属性 时 可 以 不 进行 赋值 操作 。 


8.2.3 成员 方法 


成 员 方法 是 指 在 类 中 声明 的 函数 。 在 类 中 可 以 声明 多 个 函数 ， 所 以 对 象 中 可 以 存在 多 个 成 员 
方法 。 类 的 成 员 方法 可 以 通过 关键 字 进 行 修饰 ， 从 而 控制 成 员 方法 的 使 用 权限 。 

以 下 是 定义 成 员 方 法 的 例子 : 
class Student 
lL 

Public $name; // 类 的 成 员 属性 

function GetIp(){ 

// 方 法 的 内 容 ; 
} 


8.2.4 类 的 实例 化 


面向 对 象 编程 的 思想 是 一 切 皆 为 对 象 。 类 是 对 一 个 事物 抽象 出 来 的 结果 ， 因 此 ， 类 是 抽象 的 。 
对 象 是 某 类 事物 中 具体 的 那个 ,因此 ， 对 象 就 是 具体 的 。 例 如 , 学 生 就 是 一 个 抽象 概念 , 即 学 生 类 ， 
但 是 姓名 叫 张 三 的 就 是 学 生 类 中 一 个 具体 的 学 生 ， 即 对 象 。 

类 和 对 象 可 以 描述 为 如 下 关系 。 类 用 来 描述 具有 相同 数据 结构 和 特征 的 “一 组 对 象 ”，“ 类 ?” 
是 “对 象 ”的 抽象 ， 而 “对 象 ”是 “类 ”的 具体 实例 ， 即 一 个 类 中 的 对 象 具 有 相同 的 “型 ”， 但 其 
中 每 个 对 象 却 具有 各 不 相同 的 “ 值 ”。 
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C9 类 是 具有 相同 或 相仿 结构 、 操 作 和 约束 规则 的 对 象 组 成 的 集合 ， 而 对 象 是 某 一 类 的 具 
提示 体 化 实例 ， 每 一 个 类 都 是 具有 某 些 共同 性 的 对 象 的 抽象 。 


类 的 实例 化 格式 如 下 : 


$ 变 量 名 =new 类 名 称 ( [参数 ] ) ; // 类 的 实例 化 


其 中 ，new 为 创建 对 象 的 关键 字 ，$ 变 量 名 返回 对 象 的 名 称 ， 用 于 引用 类 中 的 方法 。 参 数 是 可 
选 的 ， 如果 存在 参数 ， 则 它 用 于 指定 类 的 构造 方法 或 用 于 初始 化 对 象 的 值 ， 如果 没有 定义 构造 函数 
参数 ，PHP 会 自动 创建 一 个 不 带 参数 的 默认 构造 函数 。 

如 下 面 的 例子 所 示 : 


class Student 


{ 





Public $name; // 类 的 成 员 属性 
function GetIp(){ 
// 方 法 的 内 容 ; 

t 
} 
$1ili=new 类 名 称 () ; // 类 的 实例 化 
$1liufei=new 类 名 称 () ; // 类 的 实例 化 
$zhangming=new 类 名 称 (); // 类 的 实例 化 
S$wangyi=new 类 名 称 () ; // 类 的 实例 化 


上 面 的 例子 实例 化 了 4 个 对 象 ， 并 且 这 4 个 对 象 之 间 没 有 任何 联系 ， 只 能 说 明 它 们 源 于 同一 
个 类 。 可 见 ， 一 个 类 可 以 实例 化 多 个 对 象 ， 每 个 对 象 都 是 独立 存在 的 。 
8.2.5 ”访问 类 中 的 成 员 属性 和 方法 


通过 对 象 的 引用 可 以 访问 类 中 的 成 员 属 性 和 方法 ， 这 里 需要 使 用 特殊 的 运算 符号 : “->”。 具 
体 的 语法 格式 如 下 : 


$ 变 量 名 =new 类 名 称 () ; // 类 的 实例 化 

$ 变 量 名 -> 成 员 属 性 = 值 ; // 为 成 员 属 性 赋值 

$ 变 量 名 -> 成 员 属 性 ; // 直 接 获 取 成 员 的 属性 值 
$ 变 量 名 -> 成 员 方 法 ; // 访 问 对 象 中 指定 的 方法 
另外 ， 用 户 还 可 以 使 用 一 些 特殊 的 访问 方法 。 

1. $this 


Sthis 存在 于 类 的 每 一 个 成 员 方法 中 ， 它 是 一 个 特殊 的 对 象 引 用 方法 。 成 员 方法 属于 哪个 对 象 ， 
S$this 引用 就 代表 哪个 对 象 ， 主 要 作用 是 专门 完成 对 象 内 部 成 员 之 间 的 访问 。 
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2. 操作 符 “::” 




















操作 符 “::” 可 以 在 没有 任何 声明 实例 的 情况 下 访问 类 中 的 成 员 。 使 用 的 语法 格式 如 下 : 


关键 字 : : :变量 名 /常量 名 /方法 名 








其 中 关键 字 主 要 包括 parent、self 和 类 名 3 种 。parent 关键 字 表 示 可 以 调 





常量 和 成 员 方 法 。self 关键 字 表示 可 以 调用 当前 类 中 的 常量 和 静态 成 员 。 类 名 关键 字 表 示 可 以 调 


本 类 中 的 常量 变量 和 方法 。 
下 面 通 过 实例 介绍 类 的 声明 和 实例 的 生成 。 
【 例 8.1】〔 实 例文 件 ，ch08\8.1.php) 


<?php 
// 定 义 类 
class guestst{ 
private $name; 
Private S$gender; 
function setname ($name){ 


$this->name = $name; 


/ /定义 函数 
function getname(){ 


return $this->name; 


function setgender($gender){ 
$this->gender = S$gender; 


function getgender(){ 


return $this->gender; 





] 

$xiaoming = new guests;  // 生 成 实例 

$xiaoming->setname ("王小明 "); 

$xiaoming->setgender (" 男 ") ; 

$1ili = new guests; 

$1il1i->setname (" 李 莉 莉 "); 

$1ili->setgender (" 女 "); 

echo $xiaoming->getname()."\t".$xiaoming->getgender () ." 
echo $1ili->getname()."\t".$1ili->getgender(); 


> 


运行 结果 如 图 8-1 所 示 。 


*，126。 





父 类 中 的 成 员 变 量 、 
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王小明 男 
李 莉 莉 女 








图 8-1 程序 运行 结果 
【案例 分 析 】: 


(1) 其 中 用 class 关键 字 声 明 一 个 类 ， 而 这 个 类 的 名 称 是 guests。 在 大 括号 内 写 入 类 的 属性 和 
方法 。 其 中 private Sname、private $gender 为 类 guests 的 自 有 属性 ， 用 private 关键 字 声 明 ， 也 就 是 
说 只 有 在 类 内 部 的 方法 可 以 访问 它们 ， 类 外 部 是 不 能 访问 的 。 

(2) function setname($name)、function getname()、function setgender($gender) 和 function 
getgender() 就 是 类 方法 ， 它 们 可 以 对 private $name、private $gender 这 两 个 属性 进行 操作 。S$this 是 
对 类 本 身 的 引用 。 用 “->” 连 接 类 属性 ， 格 式 如 Sthis->name 和 S$this->gender。 

(3) 之 后 用 new 关键 字 生 成 一 个 对 象 ， 格 式 为 gobject = new Classname;， 它 的 对 象 名 是 
$xiaoming。 当 程序 通过 new 生成 一 个 类 guests 的 实例 , 也 就 是 对 象 Sxiaoming 的 时 候 , 对 象 $xiaoming 
就 拥有 了 类 guests 的 所 有 属性 和 方法 。 然 后 就 可 以 通过 “接口 ”也 就 是 这 个 对 象 的 方法 (也 就 是 类 
的 方法 的 拷贝 ) 来 对 对 象 的 属性 进行 操作 。 

(4) 通过 接口 setname($name) 给 实例 $xiaoming 的 属性 Sname 赋值 为 XiaoMing, 通过 
setgender($gender) 给 实例 $xiaoming 的 属性 $gender 赋值 为 male。 同 样 的 道理 ， 通 过 接口 操作 了 实例 
$lili 的 属性 。 最 后 通过 接口 getname()、getgender() 返 回 不 同 的 两 个 实例 的 属性 $name 和 $gender， 并 
且 打 印 出 来 。 


8.3 ”构造 方法 和 析 构 方法 


构造 方法 存在 于 每 个 声明 的 类 中 ， 主 要 作用 是 执行 一 些 初始 化 的 任务 。 如 果 类 中 没有 直接 声 
明 构造 方法 ， 那 么 类 会 默认 生成 一 个 没有 参数 且 内 存 为 空 的 构造 方法 。 
在 PHP 中 ， 声 明 构造 方法 的 方法 有 两 种 ， 在 PHP 5 版 本 之 前 ， 构 造 方法 的 名 称 必 须 与 类 名 相 
同 ， 从 PHP 5 版 本 开始 ， 构 造 方法 的 名 称 必须 以 两 个 下 划 线 开头 ， 即 “--xonstruct”。 具 体 的 语法 
格式 如 下 : 











Function--construct([mixed args]){ 


// 方 法 的 内 容 
一 个 类 只 能 声明 一 个 构造 方法 。 构 造 方 法 中 的 参数 是 可 选 的 ， 如 果 没 有 传 入 参数 ， 那 么 将 使 
用 默认 参数 为 成 员 变 量 进 行 初始 化 。 
在 例 8.1 中 ， 对 实例 $xiaoming 的 属性 Sname 进行 赋值 ， 还 需要 通过 使 用 接口 setname($name) 
进行 操作 ， 如 $xiaoming->setname("XiaoMing")。 如 果 想 在 生成 实例 $xiaoming 的 同时 就 对 此 实例 


MS 
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的 属性 $name 进行 赋值 ， 该 怎么 办 呢 ? 

这 时 就 需要 构造 方法 “_construct()” 了 。 这 个 函数 的 特性 是 ， 当 通过 关键 字 new 生成 实例 的 
时 候 , 它 就 会 被 调用 执行 。 它 的 用 途 就 是 经 常 对 一 些 属性 进行 初始 化 , 也 就 是 给 一 些 属性 进行 初始 
化 的 赋值 。 

下 面 通过 实例 介绍 构造 方法 的 使 用 方法 和 技巧 。 

【 例 8.2】〔 实 例文 件 : ch08\8.2.php) 

<?php 

class guestst{ // 定 义 类 guests 
private $name; 
Private $gender; 
function construct ($name, $gender){ // 定 义 函数 function _construct 
$this->name = $name; 
$this->gender = $gender; 
function getname(){ // 定 义 函 数 getname 
return $this->name; 
1 
function getgender(){ // 定 义 函数 getgender 
return $this->gender; 
上 
7 
$xiaoming = new guests (" 赵 大 勇 "," 男 ") ; 
$lili = new guests(" 方 芳 芳 "," 女 ") ; 
echo S$Sxiaoming->getname () ."\t".S$Sxiaoming->getgender () ."<br />"; 
echo $1ili->getname()."\t".$1ili->getgender(); 


2 


运行 结果 如 图 8-2 所 示 。 
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图 8-2 程序 运行 结果 


要 记 住 的 是 ， 构 造 方法 是 不 能 返回 (return) 值 的 。 
有 构造 方法 ， 就 有 它 的 反面 “ 析 构 方法 ” (desturctor) 。 它 是 在 对 象 被 销毁 的 时 候 被 调用 执 
行 的 。 但 是 因为 PHP 在 每 个 请 求 的 最 终 都 会 把 所 有 资源 释放 ， 所 以 析 构 方法 的 意义 是 有 限 的 。 具 
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体 使 用 的 语法 格式 如 下 : 
function destruct (){ 


// 方 法 的 内 容 ， 通 常 完 成 一 些 在 对 象 销毁 前 的 清理 任务 
} 


由 于 PHP 具有 垃圾 回收 机 制 ， 可 以 自动 清除 不 再 使 用 的 对 象 ， 从 而 释放 更 多 的 内 存 。 析 构 方 
法 在 垃圾 回收 程序 执行 前 被 调用 的 方法 ， 是 PHP 编程 中 的 可 选 内 容 。 

不 过 ， 在 执行 某 些 特定 行为 时 ， 还 是 有 用 的 ， 比 如 在 对 象 被 销毁 时 清空 资源 或 者 记录 日 志 信 
息 。 

以 下 两 种 情况 下 ， 析 构 方 法 可 能 被 调用 执行 。 

@ ”代码 运行 时 ， 当 所 有 对 于 某 个 对 象 的 reference ( 引用 ) 被 毁 掉 的 情况 下 ; 

@ 当代 码 执行 到 最 后 ， 并 且 PHP 停止 请 求 的 时 候 ， 调 用 destructor 函数 。 


8.4 访问 方法 


另 一 个 很 好 用 的 函数 是 访问 方法 (accessor) 。 由 于 OOP 思想 并 不 鼓励 直接 从 类 的 外 部 访问 类 
的 属性 ， 以 强调 封装 性 ， 所 以 可 以 使 用 _get 和 _set 方法 来 达到 此 目的 ， 也 就 是 说 要 使 用 访问 函数 。 
无 论 何 时 ， 类 属性 被 访问 和 操作 ， 访 问 方法 都 会 被 激发 。 通 过 使 用 它们 ， 可 以 避免 直接 对 类 属性 的 
访问 。 

下 面 通过 实例 介绍 访问 方法 的 使 用 方法 和 技巧 。 

【 例 8.3】〔 实 例文 件 : ch08\8.3.php) 


<?php 
class guestst{ 
public S$property; 
function _set ($propName, $propValue){ 
$this->$propName = $propValue; 
function get($propName){ 
return $this->$propName; 
} 
I 
$xiaoshuai = new guests; 
$xiaoshuai->name = " 刘 小 帅 "; 
$xiaoshuai->gender = "男性 "; 
$dingdang = new guests; 
$dingdang->name = "本 叮当" 
$dingdang->gender = "女性 "; 
$dingdang->age = 28; 
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echo $xiaoshuai->name." 是 ".$xiaoshuai->gender."<br />"; 
echo $dingdang->name." 是 二 位 ".S$dingdang->age." 岁 
".$dingdang->gender."<br />"; 
?> 


运行 结果 如 图 8-3 所 示 。 
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刘 小 帅 是 男性 
本 叮当 是 一 位 28 岁 女性 











图 8-3 程序 运行 结果 
【案例 分 析 】: 


(1)$xiaoshuai 为 类 guest 的 实例 .直接 添 加 属性 name 和 gender, 并 且 赋 值 ,如 "$xiaoshuai->name 
= " 刘 小 帅 "; $xiaoshuai->gender = "男性 ";"， 此 时 ， 类 guest 中 的 _set 函数 被 调用 。$dingdang 实例 为 
同样 的 过 程 。 另 外 ，$dingdang 实例 添加 了 一 个 对 象 属性 age。 

(2) echo 命令 中 用 到 的 对 象 属性 , 如 $xiaoshuai->name 等 , 则 是 调用 了 类 guest 中 的 _get 函数 。 

(3) 此 例 中 ，_set 方法 的 格式 为 : 


function set($propName,$propValue){ 
$this->$propName = $propValue; 
} 


_get 方法 的 格式 为 : 


function get($propName){ 
return $this->$propName; 
» 


其 中 ，$propName 为 “属性 名 ”，S$propValue 为 “属性 值 ”。 


8.5 类 的 继承 


继承 (inheritance) 是 OOP 中 最 重要 的 特性 与 概念 。 父 类 拥有 其 子 类 的 公共 属性 和 方法 。 子 
类 除了 拥有 父 类 具有 的 公共 属性 和 方法 以 外 ， 还 拥有 自己 独 有 的 属性 和 方法 。 

PHP 使 用 关键 字 extends 来 确认 子 类 和 父 类 ， 实 现 子 类 对 父 类 的 继承 。 具 体 的 语法 格式 如 下 : 
class 子 类 名 称 extends 父 类 名 称 { 

// 子 类 成 员 变量 列表 

function 成 员 方 法 () { // 子 类 成 员 方法 

// 方 法 内 容 
} 
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时 


下 面 通过 实例 介绍 类 的 继承 方法 。 
【 例 8.4】〔 实 例文 件 : ch08\8.4.php) 


<?php 
class Vegetables{ 
var $tomato =" 西 红 柿 "; // 定 义 变量 
var $cucumber=" 黄 瓜 "; 
| 
class VegetablesTYPe extends Vegetables{ // 类 之 间 的 继承 
var $potato=" 马 铃 暮 "; // 定 义 子 类 的 变量 
var $radish=" 蓝 下"; 
] 7 
$vegetables=new VegetablesType() ; /7 实例 化 对 象 
echo "蔬菜 包括 : ".S$vegetables->tomato." ，".Svegetables->t cucumber."， 
".$vegetables-> potato.", ".$vegetables-> radish; 
?> 


运行 结果 如 图 8-4 所 示 。 
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图 8-4 程序 运行 结果 


从 结果 可 以 看 出 ， 本 实例 创建 了 一 个 蔬菜 父 类 ， 子 类 通过 关键 字 extends 继承 了 蔬菜 父 类 中 的 
成 员 属 性 ， 最 后 对 子 类 进行 实例 化 操作 。 


8.6 高 级 特性 

本 节 将 学 习 PHP 中 关于 类 的 一 些 高 级 特性 。 
8.6.1 静态 属性 和 方法 

声明 类 属性 或 方法 为 static〈 静 态 ) ， 就 可 以 不 实例 化 类 而 直接 访问 。 静 态 属 性 不 能 通过 一 个 
类 已 实例 化 的 对 象 来 访问 (但 静态 方法 可 以 ) 。 由 于 静态 方法 不 需要 通过 对 象 即 可 调用 ， 所 以 伪 变 
量 Sthis 在 静态 方法 中 不 可 用 。 静 态 属性 不 可 以 由 对 象 通过 -> 操作 符 来 访问 。 自 PHP 5.3.0 起 ， 可 
以 用 一 个 变量 来 动态 调用 类 。 但 该 变量 的 值 不 能 为 关键 字 self，parent 或 static。 

静态 属性 不 需要 实例 化 就 可 以 直接 使 用 ， 调 用 格式 为 “类 名 : : 静态 属性 名 ”。 同 样 ， 静 态 方 
法 也 不 需要 实例 化 即 可 直接 使 用 ， 调 用 格式 为 “类 名 : : 静态 方法 名 ”。 





【 例 8.5】《〈 实 例文 件 ，ch08\8.5.php) 





运行 结果 如 图 8-5 所 示 。 


OE ees -ol «| 
| 洛阳 亲友 如 相间 ， 一 片 冰心 在 玉 查 。 
洛阳 亲友 如 相 问 ， 一 片 冰心 在 玉 谈 。 








图 8-5 程序 运行 结果 


8.6.2 final 类 和 方法 

从 PHP 5 开始， 新 增 了 一 个 final 关键 字 。 如 果 父 类 中 的 方法 被 声明 为 fnal， 则 子 类 无 法 覆盖 
该 方法 。 如 果 一 个 类 被 声明 为 final， 则 不 能 被 继承 。 

1.fina 方法 不 能 被 重 写 


如 果 希 望 类 中 的 某 个 方法 不 能 被 子 类 重 写 ， 可 以 将 设置 该 方法 为 final 方法 ， 只 需要 在 方法 前 
加 上 final 修饰 符 。 如 果 这 个 方法 被 子 类 重 写 ， 将 会 出 现 错误 。 
【 例 8.6】 《实例 文件 : ch08\8.6.php) 
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class M extends Math { 
public function Sum($a, $b) { // 重 写 Sum 方 法 
echo ' 这 里 先 测试 一 下 '; 


. 
Smath = new M(); 
echo $math->Sum(10,20); 


> 


运行 结果 如 图 8-6 所 示 。 从 结果 可 以 看 出 ，final 方法 不 能 被 重 写 ， 否 则 会 被 报错 。 
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图 8-6 程序 运行 结果 
2. final 类 不 能 被 继承 


final 关键 词 可 以 终止 类 的 继承 ，final 类 不 能 有 子 类 ，final 方法 不 能 被 继承 。 
【 例 8.7】 实例 文件 : ch08\8.7.php) 


<?php 
final class Poth{ 
public $aa = 9.99; 
} 
$poth = new Poth(); 
echo $poth; 
// 声 明 M 类 ， 它 继承 自 Poth 类 ， 但 执行 时 会 出 错 ，final 类 不 能 被 继承 。 


class M extends Poth { 


E 
> 


运行 结果 如 图 8-7 所 示 。 
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图 8-7 程序 运行 结果 
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8.7 ”抽象 类 和 接口 
抽象 类 和 接口 都 是 特殊 的 类 ， 因 为 它们 都 不 能 被 实例 化 。 本 章 主要 讲述 两 者 的 使 用 方法 和 技 
Ee 
8.7.1 抽象 类 


抽象 类 只 能 作为 父 类 使 用 ， 因 为 抽象 类 不 能 被 实例 化 。 抽 象 类 使 用 关键 字 abstract 来 声明 ， 具 
体 的 使 用 语法 格式 如 下 : 
abstract class 抽象 类 名 称 { 


// 抽 象 类 的 成 员 变量 列表 
abstract function 成 员 方 法 1 (参数 ) ; // 抽 象 类 的 成 员 方法 
abstract function 成 员 方 法 2 (参数 ) ; // 抽 象 类 的 成 员 方法 


} 
抽象 类 和 普通 类 的 主要 区 别 在 于 抽象 类 的 方法 没有 方法 内 容 ， 而 且 至 少 包 含 一 个 抽象 方法 。 
另外 抽象 方法 也 必须 使 用 关键 字 abstract 来 修饰 ， 抽 象 方法 后 必须 有 分 号 。 
【 例 8.8】〔 实 例文 件 ，ch08\8.8.php) 


<?php 
abstract class MyObject{ // 定 义 抽象 类 
abstract function service($getName,$price, $num); 
} 
class MyBook extends MyObject{ 
function service($getName, $price, $num){ 
echo ' 购 买 的 商品 是 ' .$getName .'， 商 品 的 价格 是 : ' .$price.' 元 。'; 
echo ' 您 购买 的 数量 为 :' .$num.， 本 。'; 


} 
class MyComputer extends MyObject{ // 继 承 抽象 类 
function service($getName, $price, $num){ 
echo ' 您 购买 的 商品 是 ' .$getName .'， 该 商品 的 价格 是 : ' . $price.' 元 。' 7 
echo ' 您 购买 的 数量 为 :' .$num.， 本 。'; 


} 

Sbook = new MyBook(); 

$computer = new MyComputer (); 

$book -> service(' 《PHP 7 从 入 门 到 精通 》' ,59, 15); 
echo '<p>'; 

$computer -> service ('MYSQL5.7 从 零 开 始 学 ' ,65,10)，; 


2 
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运行 结果 如 图 8-8 所 示 。 
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*| 
文件 (站 ”六 所 (E) 喜 看 (V) 收 训 夫 (A) 工具 MT) 帮助 (H) a 
您 购买 的 商品 是 《PHP7 从 入 门 到 精通 》， 商 品 的 价格 是 : 59 元 。 您 购买 的 数量 为 : 15 本 。 








EEMIEL.S = 








您 购买 的 商品 是 《MySQL5. 7 从 零 开始 学 )》 ， 该 商品 的 价格 是 : 65 元 。 您 购买 的 数量 为 : 10 本 。 





图 8-8 程序 运行 结果 


8.7.2 接口 


继承 特性 简化 了 对 象 和 类 的 创建 ， 增 加 了 代码 的 可 重用 性 。 但 是 PHP 只 支持 单 继承 ， 如 果 想 
实现 多 继承 ， 就 需要 使 用 接口 。PHP 可 以 实现 多 个 接口 。 

接口 类 通过 关键 字 interface 来 声明 ， 接 口中 不 能 声明 变量 ， 只 能 使 用 关键 字 const 声明 为 常量 
的 成 员 属性 , 接口 中 声明 的 方法 必须 是 抽象 方法 , 并 且 接 口中 所 有 的 成 员 都 必须 具有 public 访问 权 
限 。 具 体 的 使 用 语法 格式 如 下 : 


interface 接口 名 称 { // 使 用 interface 关键 字 声 明 接 口 
// 常 量 成 员 // 接 口中 成 员 只 能 是 常量 
// 抽 象 方法 // 成 员 方 法 必须 是 抽象 方法 


} 
与 继承 使 用 extends 关键 字 不 同 的 是 ， 实 现 接口 使 用 的 是 implement 关键 字 : 
class 接口 类 implement 接口 名 称 {} 
实现 接口 的 类 必须 实现 接口 中 声明 的 所 有 方法 ， 除 非 这 个 类 被 声明 为 抽象 类 。 
【 例 8.9】〔 实 例文 件 ，ch08\8.9.php) 


<?php 
interface Maxmin{ 

// 这 两 个 方法 必须 在 子 类 中 继承 ,修饰 符 必须 为 public 
public function getMax(); 
public function getMin(); 

} 
class msm implements Maxmin { 

Private $aa = 33; 
Private $bb = 66; 

// 具 体 实现 接口 声明 的 方法 
public function getMax(){ 

return $this->bb; 

! 
public function getMin(){ 


return $this->aa; 
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| 

// 这 里 还 可 以 有 自己 的 方法 

public function getOother()1{ 
return ' 这 里 是 自己 的 方法 '; 


} 

Smsm = new msm(); 
echo $msm->getMax(); 
echo "<br>'7 

echo $msm->getMin(); 
echo "<br>'7 

echo $msm->getOother(); 


> 


运行 结果 如 图 8-9 所 示 。 
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这 里 是 自己 的 方法 


图 8-9 程序 运行 结果 
通过 上 述 实例 ， 可 以 总 结 如 下 的 要 点 


@ 在 PHP 中 类 的 继承 只 能 是 单独 继承 ， 即 由 一 个 父 类 ( 基 类 ) 继承 ， 而 且 可 以 一 直 继 承 下 
去 。PHP 不 支持 多 方 继承 ， 即 不 能 由 一 个 以 上 的 父 类 进行 继承 ， 即 类 C 不 能 同时 继承 类 
A 和 类 B。 

@ 由 于 PHP 支持 多 方 继承 ， 为 了 对 特定 类 的 功能 进行 拓展 ， 就 可 以 使 用 接口 (interface ) 
来 实现 类 似 于 多 方 继承 的 好 处 。 接 口 用 interface 关键 字 声 明 ， 并 且 单 独 设置 接口 方法 。 

@ 一 个 类 可 以 继承 于 一 个 父 类 ， 同 时 使 用 一 个 或 多 个 接口 。 类 还 可 以 直接 继承 于 某 个 特定 
的 接口 。 

@ 类 、 类 的 属性 和 方法 的 访问 ， 都 可 以 通过 访问 修饰 符 进 行 控制 。 访 问 修饰 符 放 在 属性 和 
类 的 前 面 则 表示 public 为 公共 属性 或 方法 ，private 为 自 有 属性 或 方法 ，protected 为 可 继 
承 属性 或 方法 。 

@ 关键 字 final 放 在 特定 的 类 前 面 ， 表 示 此 类 不 能 再 被 继承 。final 放 在 某 个 类 方法 前 面 ， 表 
示 此 方法 不 能 在 继承 后 被 “ 履 写 ”或 重新 定义 。 


8.8 面向 对 象 的 多 态 性 


多 态 性 是 指 同一 操作 作用 于 不 同 的 类 的 实例 ， 将 产生 不 同 的 执行 结果 ， 即 不 同类 的 对 象 收 到 
相同 的 消息 时 ， 得 到 不 同 的 结果 。 在 PHP 中 ， 实 现 多 态 的 方法 有 两 种 ， 包 括 通过 继承 实现 多 态 和 
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8.8.1 通过 继承 实现 多 态 
通过 继承 可 以 实现 多 态 的 效果 ， 下 面 通过 一 个 实例 来 理解 实现 多 态 的 方法 。 
【 例 8.10】“《 实 例文 件 ， ch08\8.10.php) 


<?php 
abstract class Vegetables{ / /定义 抽象 类 Vegetables 
abstract function go Vegetables(); // 定 义 抽象 方法 go_Vegetables 


上 
class Vegetables_potato extends Vegetables1{ // 马 铃 暮 类 继承 蔬菜 类 


Public function go Vegetables(){ // 重 写 抽象 方法 
echo "我 们 开始 种 植 马铃薯 "” ， // 输 出 信息 
} 


} 
class Vegetables_radish extends Vegetables{ // 葛 卜 类 继承 蔬菜 类 


public function go Vegetables(){ // 重 写 抽象 方法 
echo "我 们 开始 种 植 葛 卜 " ，; 
} 


} 
function change ($0obj){ // 自 定义 方法 根据 对 象 调用 不 同 的 方法 


if($obj instanceof Vegetables ){ 
$obj->go_Vegetables (); 
}else{ 
echo " 传 入 的 参数 不 是 一 个 对 象 "; // 输 出 信息 
} 
echo "实例 化 Vegetables potato: "; 
change (new Vegetables potato()); // 实 例 化 Vegetables_potato 
echo "<br />"; 
echo "实例 化 Vegetables radish: "; 
change (new Vegetables_ radish ()); // 实 例 化 Vegetables_ radish 
2 


运行 结果 如 图 8-10 所 示 。 











(< 加 loc- @ Dp- Box| Guu x | 但 太 
文件 (月 ”篇 蚀 (E) ”查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 
实例 化 Yegetables_potato “我 们 开始 种 植 马 铃 著 ” 
实例 化 Vegetables_ radish: “我 们 开始 种 植 萝卜 ” 

瑟 100% ~ 








图 8-10 程序 运行 结果 
从 结果 可 以 看 出 ， 本 实例 创建 了 一 个 抽象 类 Vegetables， 用 于 表示 各 种 蔬菜 的 种 植 方法 ， 然 后 
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让 子 类 继承 这 个 Vegetables。 
8.8.2 ”通过 接口 实现 多 态 


下 面 通过 接口 的 方式 ， 实 现 和 上 面 实例 一 样 的 效果 。 


【 例 8.11】 《实例 文件 ， ch08\8.11.php) 


<?php 
interface Vegetables{ // 定 义 接口 Vegetables 
public function go Vegetables (); // 定 义 接口 方法 
} 
class Vegetables potato implements Vegetables{ Ek 


Vegetables_potato 实现 Vegetables 接口 
Public function go Vegetables(){ 
echo "我 们 开始 种 植 马 铃 募 "”， 
} 
} 


class Vegetables radish implements 


Vegetables_radish 实现 Vegetables 接口 
Public function go Vegetables(){ 
echo "我 们 开始 种 植 萝 卜 "” ; 
} 
} 
function change ($0bj){ 
if($obj instanceof Vegetables ){ 
$obj->go Vegetables(); 
}else{ 
echo " 传 入 的 参数 不 是 一 个 对 象 "; 
} 
echo "实例 化 Vegetables_potato: "; 
change (new Vegetables potato()); 
Vegetables potato 
echo "<br />"; 
echo "实例 化 Vegetables_radish: "; 
change (new Vegetables_ radish ()); 
radish 
> 
</body> 
</html> 


运行 结果 如 图 8-11 所 示 。 


// 定 义 go_Vegetables 方法 
// 输 出 信息 


Vegetables{ 


// 定 义 go_Vegetables 方法 
// 输 出 信息 


// 自 定义 方法 根据 对 象 调用 不 同 的 方法 


// 输 出 信息 


// 实 例 化 Vegetables_ 
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| 实例 化 Vegetables_potato: “我 们 开始 种 植 马 铃 著 ” 
实例 化 Vegetables_radish， “我 们 开始 种 植 萝卜 ” 








图 8-11 程序 运行 结果 


从 结果 可 以 看 出 ， 本 实例 创建 了 一 个 接口 Vegetables， 然 后 定义 一 个 空 方法 go_Vegetables()， 
接着 定义 Vegetables_potato 和 Vegetables_radish 子 类 承接 接口 Vegetables。 最 后 通过 instanceof 关 
键 字 检查 对 象 是 否 属于 接口 Vegetables。 


8.9 ”高 手 私房 菜 


技巧 1: 理解 “(a<b ) ?a : b;” 的 含义 

这 是 条 件 控制 语句 ， 是 让 语句 的 单行 表示 方法 。 它 的 具体 格式 是 : 

(条 件 判 断 语句 )? 判断 为 true 的 行为 : 判断 为 false 的 行为 ; 

这 语句 的 单行 表示 方式 的 好 处 是 , 可 以 直接 对 条 件 判 断 结果 的 返回 值 进行 处 理 。 比 如 可 以 直接 
把 返回 值 赋值 给 变量 。 对 于 $varible = (a < b)? a:b:， 如 果 a<b 的 结果 为 ttre， 则 此 语句 返回 a， 并 
且 直 接 赋值 给 $varible， 如 果 a<b 的 结果 为 false， 则 此 语句 返回 b， 并 且 直 接 赋值 给 $varible 。 

这 种 表示 方法 可 以 节约 代码 的 输入 量 ， 更 重要 的 是 可 以 提高 代码 执行 的 效率 。 由 于 PHP 代码 
执行 是 对 代码 由 上 至 下 的 一 个 过 程 , 所 以 代码 的 行 数 越 少 , 越 能 节约 代码 读 取 的 时 间 。 在 一 行 语句 
中 就 能 对 情况 做 出 判断 ， 并 且 对 代码 返回 值 进行 处 理 ， 这 无 疑 是 一 种 效率 相当 高 的 代码 组 织 方式 。 

技巧 2: 说 明 抽象 类 和 类 的 不 同 之 处 

抽象 类 是 类 的 一 种 , 通过 在 类 的 前 面 增加 关键 字 abstract 来 表示 。 抽象 类 是 仅仅 用 来 继承 的 类 。 
通过 abstact 关键 字 声 明 ， 就 是 告诉 PHP， 这 个 类 不 再 用 于 生成 类 的 实例 ， 仅 仅 是 用 来 被 其 子 类 继 
承 。 可 以 说 抽象 类 只 关注 于 类 的 继承 。 抽 象 方法 就 是 在 方法 前 面 添加 关键 字 abstract 声明 的 方法 。 
抽象 类 中 可 以 包含 抽象 方法 。 一 个 类 中 只 要 有 一 个 方法 通过 关键 字 abstract 声明 为 抽象 方法 ， 则 整 
个 类 都 要 声明 为 抽象 类 。 然 而 ， 特 定 的 某 个 类 即便 不 包含 抽象 方法 ， 也 可 以 通过 abstract 声明 为 抽 
象 类 。 


8.10 经典 习题 


(1) 制作 一 个 输出 当前 时 间 戳 的 例子 。 

(2) 制作 一 个 输出 当前 时 间 和 日 期 的 例子 。 
(3) 制作 一 个 包含 比较 两 个 时 间 大 小 的 例子 。 
(4) 制作 一 个 实现 倒计时 功能 的 例子 。 


a 
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当 PHP 代码 运行 时 ， 会 发 生 各 种 错误 : 可 能 是 语法 错误 ， 通 常 是 程序 员 造 成 的 编码 错误 或 错 
别 字 ; 可 能 是 拼写 错误 或 语言 中 缺少 的 功能 (可 能 由 于 浏览 器 差异 ) ; 可 能 是 由 于 来 自 服务 器 或 用 
户 的 错误 输出 而 导致 的 错误 。 当然, 也 可 能 是 由 于 许多 其 他 不 可 预知 的 因素 。 本 章 主要 讲述 错误 处 
理 和 异常 处 理 。 


本 章 学 习 目 标 


@ 了 解 常见 的 错误 和 蜡 常 
@ 掌握 处 理 错误 的 方法 
@ 掌握 处 理 异 常 的 方法 


9.1 常见 的 错误 和 异常 
错误 和 异常 是 编程 中 经 常 出 现 的 问题 。 本 节 将 主要 介绍 常见 的 错误 和 异常 。 
1. 拼写 错误 


PHP 中 的 函数 名 、 方 法 名 、 类 名 不 区 分 大 小 写 ， 但 建议 使 用 与 定义 时 相同 的 名 字 。 魔 术 常 量 不 区 
分 大 小 写 ， 但 是 建议 全 部 大 写 ， 包 括 _LINE 、_FILE 、_DIR 、_FUNCTION_、_CLASS 、 
_METHOD_、_NAMESPACE_。 知 道 这 些 规 则 ， 就 可 以 避免 大 小 写 的 错误 。 

另外 ， 编 写 代 码 时 有 时 需要 输入 中 文字 符 ， 编 程 人 员 容易 在 输 完 中 文字 符 后 忘记 切换 输入 法 ， 
从 而 导致 输入 的 小 括号 、 分 号 或 者 引号 等 出 现 错误 ， 当 然 ， 这 种 错误 输入 在 大 多 数 编程 软件 中 显示 
的 颜色 会 跟 正 确 的 输入 显示 的 颜色 不 一 样 ， 容 易 发 现 ， 但 还 是 应 该 细心 以 减少 错误 的 出 现 。 

2. 单 引 号 和 双 引 号 的 混用 

单 引号 、 双 引号 在 PHP 中 没有 特殊 的 区 别 ， 都 可 以 用 来 创建 字符 串 。 但 是 必须 使 用 同一 种 单 
或 双 引 号 来 定义 字符 串 ， 如 'Hello" 和 "Hello' 为 非法 的 字符 串 定义 。 单 引号 串 和 双 引 号 串 在 PHP 
中 的 处 理 是 不 相同 的 。 双 引 号 串 中 的 内 容 可 以 被 解释 而 且 替 换 , 而 单 引 号 串 中 的 内 容 总 被 认为 是 普 
通 字符 。 

另外 ， 缺 少 单 引 号 或 者 双 引号 也 是 经 常 出 现 的 问题 。 例 如 : 

echo "错误 处 理 的 方法 ; 

其 中 缺少 双 引 号 ， 运 行 时 会 提示 错误 。 
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3. 括号 使 用 混乱 
首先 需要 说 明 的 是 ， 在 PHP 中 ， 括 号 包含 两 种 语义 ， 可 以 是 分 隔 符 也 可 以 是 表达 式 。 例 如 : 


@ 分 隔 符 的 作用 比较 常用 ， 比 如 (1+4) *4 等 于 20。 
@ 在 (fonction01)0; 中 ,function 之 前 的 一 对 括号 作为 分 隔 符 ， 后 面 的 括号 表示 立即 执行 这 


个 方法 。 
另外 由 于 括号 的 使 用 层次 比较 多 ， 所 以 可 能 会 导致 括号 不 匹配 的 错误 ， 如 以 下 代码 所 示 ; 
If((($a==$b)and ($b==$c))and ($c==$q) { // 此 处 缺少 一 个 括号 


echo "正确 的 括号 使 用 方法 ! " 
上 


4. 等 号 与 赋值 符号 混淆 
等 号 与 赋值 符号 混淆 的 错误 一 般 出 现在 站 语句 中 ,而 且 这 种 错误 在 PHP 中 不 会 产生 错误 信息 ， 
所 以 在 查找 错误 时 往往 不 容易 被 发 现 。 比 如 : 
if(s =1) 
echo ("没有 找到 相关 信息 "); 


上 面 的 代码 在 迪 辑 上 是 没有 问题 的 , 它 的 运行 结果 是 将 1 赋值 给 了 s, 如 果 成 功 则 弹出 对 话 框 ， 
而 不 是 对 s 和 1 进行 比较 ， 这 不 符合 开发 者 的 本 意 。 

5. 缺少 美元 符号 

在 PHP 中， 设置 变量 时 需要 使 用 美元 符号 “$”， 如 果 不 添加 美元 符号 就 会 引起 解析 错误 。 

如 以 下 代码 所 示 : 

for($s =1;$s<=10;s++){ // 缺 少 一 个 变量 的 美元 符号 

echo ("缺少 美元 符号 ! "); 

} 

需要 修改 st+ 为 $s++ 即 可 。 如 果 $s<=10; 缺 少 美元 符号 ， 则 会 进入 无 限 循环 状态 。 

6. 调用 不 存在 的 常量 和 变量 

如 果 调用 没有 声明 的 常量 或 变量 ， 将 会 触发 NOTICE 错误 。 例 如 下 面 的 代码 中 ， 输 出 时 错误 
书写 了 变量 的 名 称 。 





<?php 
$abab= "错误 处 理 的 方法 " / /缺少 一 个 变量 的 美元 符号 
echo $abba; 

2 


如 果 运 行程 序 ， 会 出 现 如 图 9-1 所 示 的 错误 。 
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RT 
图 9-1 调用 不 存在 的 变量 
7. 调用 不 存在 的 文件 
如 果 调 用 不 存在 的 文件 ， 程 序 将 会 停止 运行 。 例 如 下 面 的 代码 : 
<?php 
include ("mybook.txt"); // 调 用 一 个 不 存在 的 文件 


2 


运行 后 将 会 弹出 如 图 9-2 所 示 的 错误 提示 信息 。 

















[< Er LT] 六 Far 从容 加 
文件 站 “入 哑 日 ”到 天 (V) 收 荐 关 (A) 工具 (T) 。 帮 融 (H) 




















(1!) 


cuses | 
[Time IFunction |Location 
0.0100 0696| {main}( ) [19.0.1.php:0 

















图 9-2 调用 不 存在 的 文件 
8. 环境 配置 的 错误 


如 果 环 境 配置 不 当 ， 也 会 给 运行 带 来 错误 ， 例 如 操作 系统 、PHP 配置 文件 和 PHP 的 版 本 等 ， 
如 果 配 置 不 正确 ， 将 会 提示 文件 无 法 打开 、 操 作 权限 不 具备 和 服务 器 无 法 连接 等 错误 信息 。 

首先 不 同 的 操作 系统 采用 不 同 的 路 径 格 式 ， 这 些 都 会 导致 程序 运行 错误 。 另 外 ，PHP 在 不 同 
的 操作 系统 上 的 功能 也 会 有 差异 , 数据 库 的 运行 也 会 在 不 同 的 操作 系统 中 有 问题 出 现 等 。 另外 PHP 
的 配置 也 很 重要 ， 由 于 各 个 计算 机 的 配置 方法 不 尽 相同 ， 当 程序 的 运行 环境 发 生变 化 时 ， 也 会 出 现 
这 样 或 那样 的 问题 。 最 后 是 PHP 的 版 本 问题 ，PHP 的 高 版 本 在 一 定 程度 上 可 以 兼容 低 版 本 ， 但 是 
高 版 本 编写 的 程序 到 低 版 本 中 运行 , 会 出 现 意 想 不 到 的 问题 , 这 些 都 是 有 关 环境 配置 的 不 同 而 引起 
的 错误 。 


.142 。 
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9. 数据 库 服 务 器 连接 错误 


由 于 PHP 应 用 于 动态 网 站 的 开发 , 所 以 经 常会 对 数据 库 进行 基本 的 操作 , 在 操作 数据 库 之 前 ， 
需要 连接 数据 库 服务 ， 如 果 用 户 名 或 者 密码 设置 不 正确 , 或 者 数据 库 不 存在 , 或 者 数据 库 的 属性 不 
允许 访问 等 ， 都 会 在 程序 运行 中 出 现 错 误 。 

例如 以 下 的 代码 ， 在 连接 数据 库 的 过 程 中 ， 密 码 编写 是 错误 的 。 


<?php 
$conn=mysqli_ connect ("localhost", "root", "root"); // 连 接 MySQL 


运行 后 将 会 弹出 如 图 9-3 所 示 的 错误 提示 信息 。 
[< 同 站 hapylocalhosuchos/9Q Lphp -ce| 划 ecohoa x[ | 


ER ET TOEO] 








(1) 


| 
| oo | 3s0696l{main}O 








|Cansack | 
Memory [Fanction ocation 
350696|{main}() -9.0.1.php:0 








图 9-3 无 法 连接 数据 库 


9.2 ”错误 处 理 


常见 的 错误 处 理 方法 包括 使 用 错误 处 理 机 制 、 使 用 DIE 语句 调试 、 自 定义 错误 和 错误 触发 器 
等 。 本 节 将 讲述 如 何 处 理 程序 中 的 错误 。 
9.2.1 php.ini 中 的 错误 处 理 机 制 


在 前 面 的 实例 中 ， 错 误 提示 会 显示 错误 的 信息 ， 如 错误 文件 的 行 号 等 ， 这 是 PHP 最 基本 的 错 
误 报告 机 制 。php.ini 文件 规定 了 错误 的 显示 方式 ， 包 括 配置 选项 的 名 称 、 默 认 值 和 表述 的 含义 等 
常见 的 错误 配置 选项 的 内 容 如 表 9-1 所 示 。 


"143。 
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表 9-1 常见 的 php.ini 文件 中 控制 错误 显示 的 配置 选项 含义 

















名 称 默认 值 
i i 设置 错误 作为 PHP 的 一 部 分 输出 。 开 发 的 过 程 中 可 以 采用 默认 的 设 
= 置 ， 但 是 为 了 安全 考虑 ， 在 生产 环境 中 还 是 设置 为 O 任 比较 好 
这 个 设置 会 显示 所 有 的 出 错 信息 。 这 种 设置 会 让 一 些 无 害 的 提示 也 显 
error reporting Eall 示 , 所 以 可 以 设置 error_reporting 的 默认 值 为 error reporting =E_ALL 
& ~E_NOTICE， 这 样 只 会 显示 错误 和 不 良 编码 
i 设置 记录 错误 日 志 的 文件 。 默 认 情况 下 将 错误 发 送 到 Web 服务 器 日 
二 志 ， 用 户 也 可 以 指定 写 入 的 文件 
html_errors On 控制 是 否 在 错误 信息 中 采用 HTML 格式 
log errors Off 控制 是 否 应 该 将 错误 发 送 到 主机 服务 器 的 日 志文 件 
display_startup_errors | Off 控制 是 否 显示 PHP 启动 时 的 错误 
track_errors Off 设置 是 否 保存 最 近 一 个 警告 或 错误 信息 








9.2.2 应 用 DIE 语句 调试 


使 用 DIE 语句 调试 的 优势 是 ， 不 仅 可 以 显示 错误 的 位 置 ， 还 可 以 输出 错误 信息 。 一 旦 出 现 错 
误 ， 程 序 将 会 终止 运行 ， 并 在 浏览 器 上 显示 出 错 之 前 的 信息 和 错误 信息 。 

在 上 一 节 中 曾经 介绍 用 不 存在 的 文件 会 提示 错误 信息 ， 如 果 运 用 DIE 调试 ， 将 会 输出 自 定义 
的 错误 信息 。 

【 例 9.1】《〈 实 例文 件 : ch09\9.1.php) 





<?php 
if(!file exists("welcome.txt")){  ”// 判 断 文件 是 否 存 在 
die ("文件 不 存在 "); 
. 
elsef 
$file=fopen ("welcome.txt","r"); 
} 


2 


运行 后 结果 如 图 9-4 所 示 。 








Eee 区 可 
OS @htp//loc. @ P - BO Xx|E ores 


文件 (有 ” 编 邵 (E) ”过 看 (V)” 收 训 夫 (A) 工具 MT) 帮助 0) 
文件 不 存在 




















100% ~ 





图 9-4 应 用 DIE 语句 调试 


和 基本 的 错误 报告 机 制 相 比 ， 使 用 DIE 语句 调试 显得 更 有 效 ， 这 是 由 于 它 采 用 了 一 个 简单 的 
错误 处 理 机 制 ， 在 错误 之 后 终止 了 脚本 。 
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9.2.3 自 定 义 错误 和 错误 触发 器 

简单 地 终止 脚本 并 不 是 恰当 的 方式 。 本 节 将 讲述 如 何 自 定义 错误 和 错误 触发 器 。 创 建 一 个 自 
定义 的 错误 处 理 器 非常 简单 ,， 用户 可 以 创建 一 个 专用 函数 , 然后 在 PHP 中 发 生 错 误 时 调用 该 函数 。 

自 定义 的 错误 函数 的 语法 格式 如 下 : 

error_function (error level,error message,error file,error line,error conte 
EY 

该 函数 必须 至 少 包含 error level 和 error message 下 划 线 两 个 参数 , 另外 3 个 参数 , 即 error file、 
error_line 和 error_context 是 可 选 的 。 各 个 参数 的 具体 含义 如 表 9-2 所 示 。 


表 9-2 各 个 参数 的 含义 


参数 
ermror level 必需 参数 。 为 用 户 定义 的 错误 规定 错误 报告 级 别 。 必 须 是 一 个 整数 
必需 参数 。 为 用 户 定义 的 错误 规定 错误 消息 


可 选 参数 。 规 定 错误 在 其 中 发 生 的 文件 名 
| error line ”| 可 选 参数 。 规 定 错误 发 生 的 行 号 
可 选 参数 。 规 定 一 个 数组 ， 包 含 当铺 误 发 生 时 在 用 的 每 个 变量 以 及 它们 的 什 

参数 error_level 定义 错误 规定 的 报告 级 别 ,这些 错误 报告 级 别 是 错误 处 理 程序 旨 在 处 理 的 错误 
的 不 同类 型 。 具 体 的 级 别 值 和 含义 如 表 9-3 所 示 。 





表 9-3 错误 的 级 别 值 和 含义 






非 致 命 的 run-time 错误 。 不 暂停 脚本 执行 
Run-time 通知 。 脚 本 发 现 可 能 有 错误 发 生 ， 但 也 可 能 在 脚本 正常 运 
行 时 发 生 
致命 的 用 户 生成 的 错误 。 这 类 似 于 程序 员 使 用 PHP 函数 
trigger_error() 设置 的 E_ERROR 

非 致命 的 用 户 生成 的 警告 。 这 类 似 于 程序 员 使 用 PHP 函数 
trigger_ error0 设 置 的 E WARNING 

用 户 生成 的 通知 。 这 类 似 于 程序 员 使 用 PHP 函数 trigger_error() 设 
置 的 E NOTICE 


E WARNING 









8 E_NOTICE 





256 E_USER ERROR 







512 E_USER WARNING 






1024 | E USER NOTICE 
4096 E_RECOVERABLE_ ERROR | 可 捕获 的 致命 错误 。 类似 E_ ERROR， 但 可 被 用 户 定义 的 处 理 程序 捕获 
8191 E ALL 所 有 错误 和 警告 

下 面 通过 实例 来 讲解 如 何 自 定义 错误 和 错误 触发 器 。 

首先 创建 一 个 处 理 错误 的 函数 : 




















function customError ($errno, $errstr) 

{ 

echo "<b> 错 误 :</b> [$errno] S$errstr<br />"; 
echo "终止 程序 "; 

die(); 





PHP+MySOQL 动态 网 站 开发 从 入 门 到 精通 〈 视 频 教学 版 ) 





上 面 的 代码 是 一 个 简单 的 错误 处 理 函 数 。 当 它 被 触发 时 ， 它 会 取得 错误 级 别 和 错误 消息 。 然 
后 输出 错误 级 别 和 消息 ， 并 终止 程序 。 

创建 了 一 个 错误 处 理 函 数 后 ， 下 面 需要 确定 在 何 时 触发 该 函数 。 在 PHP 中 ， 使 用 
set_error handler() 函数 设置 用 户 自 定义 的 错误 处 理 函 数 。 该 函数 用 于 创建 运行 时 的 用 户 自 己 的 错 
误 处 理 方法 。 该 函数 会 返回 旧 的 错误 处 理 程序 ， 若 失败 ， 则 返回 null。 具 体 的 语法 格式 如 下 : 





Set_error_ handler (error_functionverror_types) 


其 中 ，error_function 为 必需 参数 ， 规 定 发 生 错误 时 运行 的 函数 。error_types 是 可 选 参数 ， 如 果 
不 选择 此 参数 ， 则 表示 默认 值 为 E_ALL。 
在 本 例 中 ， 由 于 针对 所 有 错误 来 使 用 自 定义 错误 处 理 程 序 ， 具 体 的 代码 如 下 : 


set_error handler("customError"); 


下 面 通过 尝试 输出 不 存在 的 变量 ， 来 测试 这 个 错误 处 理 程序 。 
【 例 9.2】 实例 文件 ，ch09\9.2.php) 


<?php 
// 定 义 错误 函数 
function customError($errno, $errstr){ 
echo "<b> 错 误 :</b> [$errno] $errstr"; 
} 
// 设 置 错误 函数 的 处 理 
set_error handler("customError"); 
// 触 发 自 定义 错误 函数 
echo ($test); 
2 


运行 后 结果 如 图 9-5 所 示 。 











ols lec.. BD- 2cxle Pw 


文件 (月 ” 连 铝 (E) 查看 (V) 收藏 夫 (A) 工具 











错误 : [8] Undefined variable: test 





图 9-5 自 定义 错误 





在 脚本 中 用 户 输入 数据 的 位 置 ， 当 用 户 的 输入 无 效 时 触发 错误 。 在 PHP 中 ， 这 个 任务 由 
trigger_error() 完 成 。 
trigger_error() 函数 创建 用 户 自 定义 的 错误 消息 。trigger_error() 用 于 在 用 户 指定 的 条 件 下 触发 
一 个 错误 消息 。 它 与 内 建 的 错误 处 理 器 一 同 使 用 ， 也 可 以 与 由 set_error_handler() 函数 创建 的 用 户 
自 定义 函数 一 起 使 用 。 如 果 指 定 了 一 个 不 合法 的 错误 类 型 ， 该 函数 返回 false， 否 则 返回 true。 
trigger_error() 函数 的 具体 语法 格式 如 下 : 
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trigger error(error message,error types) 


其 中 error message 为 必需 参数 ， 规 定 错 误 消息 ， 长 度 限 制 为 1024 个 字符 。error types 为 可 
选 参数 ， 规 定 错误 消息 的 错误 类 型 ， 可 能 的 值 为 E_ USER_ERROR、E_USER_WARNING 和 
E_USER_NOTICE。 

【 例 9.3】《〈 实 例文 件 : ch09\9.3.php) 


<?php 
$test=5; 
if ($test>4){ 
trigger error("Value must be 4 or below"); // 创 建 自 定义 错误 信息 
} 


i 


运行 后 结果 如 图 9-6 所 示 。 由 于 test 数值 为 5， 将 会 则 发 生 E_USER_WARNING 错误 。 











-le 






















/localhost/chO 











Dls 31 PD CE vigger error0 EA 
文件 (” 稀 (E) 查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 








ET EE 
reer error C) |. \9. 3. pnp:10 











图 9-6 ”trigger_error() 函数 
下 面 通过 实例 来 讲述 trigger_error() 函数 和 自 定义 函数 一 起 使 用 的 处 理 方法 。 
【 例 9.4】〔 实 例文 件 ，ch09\9.4.php) 


<?php 
// 定 义 错误 函数 
function customError($errno, $errstr){ 
echo "<b> 错 误 :</b> [$errno] S$errstr"; 
} 
// 设 置 错误 函数 的 处 理 
set error handler("customError",E USER WARNING); 
// trigger_error 函数 
$test=5; 
if ($test>4){ 
trigger error("Value must be 4 or below",E USER WARNING); 
上 
?> 


运行 后 结果 如 图 9-7 所 示 。 
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文件 (有 ”六 汤 [E) 去 吾 (V) 收 读 去 (A) 工具 (] 其 动 (H) 




















错误 : [512] Yalue must be 4 or below 





碟 100% 





图 9-7 自 定 义 函数 和 trigger_error() 函数 
9.2.4 ”错误 记录 
默认 情况 下 ， 根 据 php.ini 中 的 error_log 配置 ，PHP 向 服务 器 的 错误 记录 系统 或 文件 发 送 错 
误 记录 。 通 过 使 用 error_log() 函数 ， 用 户 可 以 向 指定 的 文件 或 远程 目的 地 发 送 错 误 记录 。 
通过 电子 邮件 向 用 户 自 己 发 送 错误 消息 ， 是 一 种 获得 指定 错误 的 通知 的 好 办 法 。 下 面 通 过 实 
例 的 方式 来 讲解 。 
【 例 9.5】 (实例 文件 ，ch09\9.5.php) 通过 email 发 送 错误 信息 


<?php 
// 定 义 错误 函数 
function customError($errno, $errstr){ 
echo "<b> 错 误 :</b> [$errno] Serrstr <br/>"; 
echo "错误 记录 已 经 发 送 完 毕 "; 
error log(" 错误: [$errno] S$errstr",l, "someone@example.com", "From: 
webmastere@example.com "); 
上 
// 设 置 错误 函数 的 处 理 
set_error handler("customError",E USER WARNING); 
// trigger_error 函数 
$test=5; 
if ($test>4){ 
trigger error("Value must be 4 or below",E USER WARNING); 
3 
2 


运行 后 结果 如 图 9-8 所 示 。 在 指定 的 someone@example.com 邮箱 中 将 收 到 同样 的 错误 信息 。 


GS 铺 hp//oc. @ PD- Box| erorlog0 Ba 


文件 (有 ”篇 缉 (E) 查看 (V) 收藏 夫 (A) 工具 (T 者 动 (H) 


























错误 : [512] Yalue must be 4 or below 
错误 记录 已 经 发 送 完毕 














图 9-8 error log 函数 
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9.3 ”异常 处 理 


异常 (Exception) 用 于 在 指定 的 错误 发 生 时 改变 脚本 的 正常 流程 。 PHP 7 提供 了 一 种 新 的 面向 
对 象 的 错误 处 理 方法 。 本 节 主 要 讲述 异常 处 理 的 方法 和 技巧 。 


9.3.1 异常 的 基本 处 理 方法 


异常 处 理 用 于 在 指定 的 错误 (异常 情况 发 生 时 改变 脚本 的 正常 流程 。 当 异常 被 触发 时 ， 通 
常会 发 生 以 下 动作 : 

(1) 当前 代码 状态 被 保存 。 

(2) 代码 执行 被 切换 到 预定 义 的 异常 处 理 器 函数 。 

(3) 根据 情况 ， 处 理 器 也 许 会 从 保存 的 代码 状态 重新 开始 执行 代码 ， 终 止 脚本 执行 ， 或 从 代 
码 中 另外 的 位 置 继续 执行 脚本 。 

当 异 常 被 抛 出 时 ， 其 后 的 代码 不 会 继续 执行 ， PHP 会 尝试 查找 匹配 的 catch 代码 块 。 如 果 蜡 常 
没有 被 捕获 , 而 且 又 没 用 使 用 set_exception_handler() 作 相应 的 处 理 的 话 , 那么 将 发 生 一 个 严重 的 错 
误 ， 并 且 输 出 Uncaught Exception 〈 未 捕获 异常 ) 的 错误 消息 。 

下 面 的 实例 抛 出 一 个 异常 ， 同 时 不 去 捕获 它 。 

【 例 9.6】 (实例 文件 ，ch09\9.6.php) 





<?php 
// 创 建 带 有 异常 的 函数 
function checkNum($number){ 
if ($number>1){ 
throw new Exception("Value must be 1 or below"); 
} 
return true; 


有 








// 抛 出 异常 
checkNum(2) 7 
?> 
运行 后 结果 如 图 9-9 所 示 。 由 于 没有 捕获 异常 ， 出 现 了 下 面 的 错误 提示 消息 。 
@os Hapyyiccalheaych09/96php P- csms x| | ee 


文 级 。 旷 者 E】 本 和 EM 避让 (A】 工具 (7 四 二 (H] 





lMemory Function on 
352056|{main} ( ) 6. php:0 


352056|checkNum( ) | . . \9. 6. php:15 











图 9-9 没有 捕获 异常 


el 
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如 果 想 避免 出 现 上 面 的 错误 ， 需 要 创建 适当 的 代码 来 处 理 异 常 。 处 理 异常 的 程序 应 当 包 括 如 
下 几 部 分 。 
@ try 代码 块 : 使 用 异常 的 函数 应 该 位 于 try 代码 块 内 。 如 果 没有 触发 异常 ， 则 代码 将 照常 
继续 执行 。 但 是 如 果 异 常 被 触发 ， 会 抛 出 一 个 异常 。 
@ throw 代码 块 : 这 里 规定 如 何 触发 异常 。 每 一 个 throw 必须 对 应 至 少 一 个 catch。 
@ catch 代码 块 : catch 代码 块 会 捕获 异常 ， 并 创建 一 个 包含 异常 信息 的 对 象 。 
【 例 9.7】 《实例 文件 : ch09\9.7.php) 


<?php 
// 创 建 可 抛 出 一 个 异常 的 函数 
function checkNum(Snumber) { 
if ($number>1){ 
throw new Exception ("数值 必须 小 于 或 等 于 1"); 
} 
return true; 
i 
// 在 try 代码 块 中 触发 异常 
try{ 
checkNum(2) 7 
// 如 果 没有 异常 ， 则 会 显示 以 下 信息 
echo ' 没 有 任何 异常 ' 7 
} 
// 捕 获 异 常 
catch (Exception S$e){ 
echo ' 异 常 信息 : ' .Se->getMessage () ; 
} 
> 


运行 后 结果 如 图 9-10 所 示 。 由 于 抛 出 异常 后 ， 捕 获 了 异常 ， 所 以 出 现 了 下 面 的 提示 消息 。 





























一 [二 Ta 
| mo/oc. B DP- SOx oates x 
TN a(F) ESV Wash) LEM BH) 
异常 信息 : 数值 必须 小 于 或 等 于 1 
Rl00% 





图 9-10 ”捕获 异常 


【案例 分 析 】: 
(1) 首先 创建 checkNum() 函 数 。 它 检测 数字 是 否 大 于 1。 如 果 是 ， 则 抛 出 一 个 异常 。 
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(2) 在 try 代码 块 中 调用 checkNum() 函数 。 

(3) checkNum() 函数 中 的 异常 被 抛 出 。 

(4) catch 代码 块 接收 到 该 异常 ， 并 创建 一 个 包含 异常 信息 的 对 象 ($e)。 

(5) 通过 从 这 个 exception 对 象 调用 $e->getMessage()， 输 出 来 自 该 异常 的 错误 消息 。 


9.3.2” 自 定义 的 异常 处 理 器 


创建 自 定义 的 异常 处 理 程序 非常 简单 。 只 需要 创建 一 个 专门 的 类 ， 当 PHP 中 发 生 异常 时 ， 调 
用 该 类 的 函数 即 可 。 当 然 ， 该 类 必须 是 exception 类 的 一 个 扩展 。 

这 个 自 定义 的 exception 类 继承 了 PHP 的 exception 类 的 所 有 属性 ， 然 后 用 户 可 向 其 添加 自 定 

下 面 通过 实例 讲解 如 何 创建 自 定义 的 异常 处 理 器 。 

【 例 9.8】《〈 实 例文 件 : ch09\9.8.php) 





<body> 
<?php 
class customException extends Exception{ 
public function errorMessage(){ 
// 错 误 消息 
$errorMsg = ' 异 常 发 生 的 行 : '.$this->getLine().' in '.$this->getFile() 
.1: <b>'.$this->getMessage() .'</b> 不 是 一 个 有 效 的 邮箱 地 址 '; 
return $errorMsg; 
} 
} 
$email = "someone@example.321com"; 
try 
// 检 查 是 否 符合 条 件 
if (filter var($email, FILTER VALIDATE EMAIL) === FALSE) { 
7/ 如果 邮件 地 址 无 效 ， 则 抛 出 异常 
throw new customException ($email); 
} 
上 
catch (customException S$e){ 
// 显 示 自 定义 的 消息 
echo $e->errorMessage(); 
} 
> 


运行 后 结果 如 图 9-11 所 示 。 
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图 9-11 自 定 义 异 常 处 理 器 
【案例 分 析 】: 


(1) customException() 类 是 作为 旧 的 exception 类 的 一 个 扩展 而 创建 的 。 这 样 它 就 继承 了 旧 类 
的 所 有 属性 和 方法 。 

(2) 创建 errorMessage() 函 数 。 如 果 email 地 址 不 合法 ， 则 该 函数 返回 一 条 错误 消息 。 

(3) 把 Semail 变量 设置 为 不 合法 的 email 地址 字符 串 。 

(4) 执行 try 代码 块 ， 由 于 email 地 址 不 合法 ， 因 此 抛 出 一 个 异常 。 

(5) catch 代码 块 捕获 异常 ， 并 显示 错误 消息 。 


9.3.3 处理 多 个 异常 


在 上 面 的 实例 中 只 是 检查 了 邮箱 地 址 是 否 有 效 。 如 果 用 户 想 检查 邮箱 是 否 为 雅虎 邮箱 ， 或 检 
查 邮箱 是 否 有 效 等 ， 就 会 出 现 多 个 可 能 发 生 异 常 的 情况 。 用 户 可 以 使 用 多 个 if…else 代码 块 ， 或 一 
个 switch 代码 块 ， 或 者 藤 套 多 个 异常 。 这 些 异 常 能 够 使 用 不 同 的 exception 类 ， 并 返回 不 同 的 错误 
消息 。 

【 例 9.9】 实 例文 件 : ch09\9.9.php) 


<?php 

class customException extends Exception{ 

public function errorMessage(){ 

// 定 义 错误 信息 

$errorMsg = ' 错 误 消息 的 行 : ' . Sthis->getLine () .' in '.Sthis->getFile() 

.1: <b>'.Sthis->getMessage () .'</b> 不 是 一 个 有 效 的 邮箱 地 址 ' ; 

return S$errorMsg; 

$email = "someone@yahoo.com"; 

tryt{ 

// 检 查 是 否 符合 条 件 

if (filter var($email, FILTER VALIDATE EMAIL) === FALSE) 
{ 
// 如 果 邮 箱 地 址 无 效 ， 则 抛 出 异常 
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throw new customException ($email); 
} 

// 检 查 邮 箱 是 否 是 雅虎 邮箱 

if(strpos ($email, "yahoo") !== FALSE){ 
throw new Exception("$email 是 一 个 雅虎 邮箱 ") ; 
} 

} 

catch (customException $e) { 

echo $e->errorMessage(); 

; 

catch (Exception $e) { 

echo $e->getMessage(); 

. 


?> 
运行 后 结果 如 图 9-12 所 示 。 上 面 的 代码 测试 了 两 种 条 件 ， 如 果 任 一 条 件 不 成 立 ， 则 抛 出 一 个 
FE 区 本 


国 js epwoc- B PP- acx] 人 xz 人 RS 
文件 (月 ”编辑 (E) ”查看 (V) ”收藏 闪 (A) 工具 (T) 帮助 (H) 


someone@yahoo. com 是 一 个 雅虎 邮箱 
































起 100% ~ 

图 9-12 处理 多 个 异常 

【案例 分 析 】: 

(1) customException() 类 是 作为 旧 的 exception 类 的 一 个 扩展 而 创建 的 。 这 样 它 就 继承 了 旧 类 
的 所 有 属性 和 方法 。 

(2) 创建 errorMessage() 函 数 。 如 果 email 地 址 不 合法 ， 则 该 函数 返回 一 个 错误 消息 。 

(3) 执行 try 代码 块 ， 在 第 一 个 条 件 下 ， 不 会 抛 出 异常 。 

(4) 由 于 email 含有 字符 串 yahoo， 第 二 个 条 件 会 触发 异常 。 

(5) catch 代码 块 会 捕获 异常 ， 并 显示 恰当 的 错误 消息 。 


9.3.4 设置 顶层 异常 处 理 器 


所 有 未 捕获 的 异常 ， 都 可 以 通过 顶层 异常 处 理 器 来 处 理 。 顶 层 异 常 处 理 器 使 用 set_exception_ 
handler() 函 数 来 实现 。 
set_exception_handler() 函 数 设置 用 户 自 定义 的 异常 处 理 函 数 。 该 函数 用 于 创建 运行 期 间 用 户 自 
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己 的 异常 处 理 方法 。 该 函数 会 返回 旧 的 异常 处 理 程序 , 若 失 败 , 则 返回 null。 具体 的 语法 格式 如 下 : 
Set _ exception handler (exception function) 


其 中 exception_function 参数 为 必需 参数 ， 规 定 未 捕获 的 异常 发 生 时 调用 的 函数 ， 该 函数 必须 
在 调用 set_exception_handler() 函数 之 前 定义 。 这 个 异常 处 理 函 数 需要 一 个 参数 ， 即 抛 出 的 
exception 对 象 。 

【 例 9.10】 (实例 文件 ，ch09\9.10.php ) 


<?php 
function myException ($exception) { // 定 义 顶 层 的 异常 处 理 程序 
echo "<b> 异 常 是 :</b> " ， S$exception->getMessage(); 
上 
Set_exception handler('myException'); 
throw new Exception(' 下 在 处 理 未 被 捕获 的 异常 '); ”// 抛 出 异常 信息 


运行 后 结果 如 图 9-13 所 示 。 上 面 的 代码 不 存在 catch 代码 块 ， 而 是 触发 项 层 的 异常 处 理 程序 。 
用 户 应 该 使 用 此 函数 来 捕获 所 有 未 被 捕获 的 异常 。 











Ols hpVhloc- 二 及 - 晤 CX | 各 克 RR 处 再 


文件 (六 (E) ” 音 看 (V) 收藏 闪 (A) 工具 (T) 帮助 (H) 








异常 是 : 正在 处 理 未 被 捕获 的 异常 





或 100% ~ 





图 9-13 顶层 异常 处 理 器 


9.4 ”实战 演练 一 一 处 理 异 常 或 错误 


错误 处 理 也 叫 意外 处 理 。 通 过 使 用 try…throw…catch 结构 和 一 个 内 置 函数 Exception() 来 “ 抛 
出 ”和 “处 理 ” 错 误 或 异常 。 

下 面 通过 打开 文件 的 实例 介绍 意外 的 处 理 方法 和 技巧 。 

【 例 9.11】 《实例 文件 :chl0\9.11.php) 





<?php 
$DOCUMENT ROOT = $_SERVER['DOCUMENT ROOT']; // 定 义 变量 
Q@$fp = fopen("$DOCUMENT ROOT/book.txt", 'rb'); // 打 开 指定 文件 book.txt 
// 判 断 文件 是 否 存在 ， 不 存在 则 抛 出 异常 
tryt{ 
ea 
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throw new Exception(" 文 件 路 径 有 误 或 找 不 到 文件 。") ; 
} 
}catch (Exception $exception){ 
echo $exception->getMessage(); 
echo "在 文件 ". $exception->getFile()." 的 ".$exception->getLine() ." 行 。<br 
J 
} 
@fclose ($fp); // 屏 蔽 错误 信息 


> 


运行 结果 如 图 9-14 所 示 。 








Es 


[¢ 回 @ huedloc. @ P- BCx| 二 


文件 (月 ”六 铝 (E) ”可 看 (V】 ” 收 茂 闪 (A) 工具 (T) 帮助 (H) 


文件 路 径 有 误 或 找 不 到 文件 。 在 文件 
C:\ch09\9. 11, php 的 11 行 。 

















图 9-14 程序 运行 结果 


【案例 分 析 】: 

(1) fopen() 函 数 打 开 $DOCUMENT_ROOT/book.txt 文件 进行 读 取 ， 但 是 由 于 book.txt 文件 不 
存在 ， 则 $fp 为 false。 

(2) try 区 块 判断 $fp 为 false 时 ， 抛 出 一 个 异常 。 此 异常 直接 通过 new 关键 字 生 成 Exception() 
类 的 实例 。 异 常 信息 是 传 入 参数 定义 的 “文件 路 径 有 误 或 找 不 到 文件 ”。 

(3) catch 区 块 通过 处 理 传 入 的 Exception() 类 实例 , 显示 出 错误 信息 、 错误 文 件 、 错误 发 生 行 。 
这 些 是 通过 直接 调用 Exception() 类 实例 $exception 的 内 置 类 方法 获得 。 错 误 信息 由 getMessage() 生 
成 ， 错 误 文件 由 getFile() 生 成 ， 错 误 发 生 行 由 getLine() 生 成 。 

(4) @felose0 和 @$fp= fopen() 中 的 “@” 表 示 屏 蔽 此 命令 的 执行 中 产生 的 错误 信息 。 


9.5 ”高 手 私房 菜 


技巧 1: 处 理 异常 有 什么 规则 ? 

在 处 理 异常 时 ， 有 以 下 规则 需要 用 户 牢 牢 掌握 。 

(1) 需要 进行 异常 处 理 的 代码 应 该 放 入 try 代码 块 内 ， 以 便 捕 获 潜在 的 异常 。 
(2) 每 个 try 或 throw 代码 块 必须 至 少 拥有 一 个 对 应 的 catch 代码 块 。 

(3) 使 用 多 个 catch 代码 块 可 以 捕获 不 同 种 类 的 异常。 

(4) 可 以 在 try 代码 块 内 的 catch 代码 块 中 再 次 抛 出 (re-thrown》〉 异常。 
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技巧 2: 如何 隐 藏 错误 信息 ? 
PHP 提供 了 一 种 隐藏 错误 的 方法 ， 就 是 在 被 调用 的 函数 名 前 加 “@” 符 号 ， 这 样 会 隐藏 可 能 
由 于 这 个 函数 导致 的 错误 信息 。 


例如 以 下 代码 : 

<?php 
$ab=fopen ("123.txt","r"); // 打 开 指 定 的 文件 
fclose(); // 关 闭 指定 的 文件 

yi 


由 于 指定 的 文件 不 存在 ， 所 以 运行 后 会 弹出 如 图 9-15 所 示 的 错误 信息 。 
| 


二 ntp//loc.. @ PD Scx| localhost x Ix) 
文 作坊 ( 日 本 看 (V) 收 训 天 (A| 工具 (T) 孝 tb(H) 









































Function Location 
: 从 0.0005 138480| nain] ( ) 1. php:0 
2 | 0.0138 139072 lzopen ( ) ppp 








1 Function Location | 
| 0.0005 | 138480| fmain] ( ) | \l.php:0 | 
2| 00155 | 139224lfelcse () ALphp:3 | 




















图 9-15 程序 运行 结果 
如 果 在 fopen0) 函 数 和 fclose0 函 数 前 加 上 “@” 符 号 ， 再 次 运行 程序 时 ， 就 不 会 出 现 上 述 的 错 
误 信 息 。 这 种 隐藏 信息 的 方法 对 于 查找 错误 的 位 置 是 很 有 帮助 的 。 
技巧 3: PHP 7 在 异常 处 理 方面 有 什么 新 变化 ? 


PHP 7 改变 了 大 多 数 错误 的 报告 方式 。 不 同 于 PHP 5 的 传统 错误 报告 机 制 , 现在 大 多 数 错误 被 
作为 Error 异常 抛 出 。 这 种 Error 异常 可 以 像 普通 异常 一 样 被 try/catch 块 所 捕获 。 如 果 没 有 匹配 的 
try/catch 块 ， 则 按照 传统 方式 处 理 : 被 报告 为 一 个 致命 错误 〈Fatal Error) 。 


9.6 经典 习题 


(1) 制作 一 个 包含 错误 处 理 的 例子 。 

(2) 制作 一 个 包含 异常 处 理 的 例子 。 

(3) 制作 一 个 处 理 数据 库 连接 失败 的 例子 。 
(4) 制作 一 个 处 理 环境 配置 错误 的 例子 。 
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第 10 章 PHP 与 Web 页 面 的 交互 


PHP 是 一 种 专门 用 于 Web 开发 的 服务 器 端 脚本 语言 。 从 这 个 描述 可 以 知道 ，PHP 要 打交道 的 
对 象 主要 有 服务 器 〈server) 和 基于 Web 的 HTML ( 超 文本 标识 语言 ，。 使 用 PHP 处 理 Web 应 用 
时 ， 需 要 把 PHP 代码 嵌入 到 HTML 文件 中 。 每 次 当 这 个 HTML 网 页 被 访问 的 时 候 ， 其 中 嵌入 的 
PHP 代码 就 会 被 执行 ， 并 且 返 回 给 请 求 浏览 器 以 生成 好 的 HTML。 换 名 话说 ， 在 上 述 过 程 中 ，PHP 
就 是 用 来 被 执行 且 生 成 HTML 的 。 本 章 主要 讲述 PHP 与 Web 页 面 的 交互 操作 技术 。 


本 章 学 习 目 标 





了 解 使 用 动态 内 容 

掌握 表单 与 PHP 的 联系 
掌握 表单 设计 的 方法 
掌握 传递 数据 的 方法 

掌握 获取 表单 数据 的 方法 

掌握 对 URL 传递 的 参数 进行 编码 的 方法 


10.1 使 用 动态 内 容 


为 什么 要 使 用 动态 内 容 呢 ? 因为 动态 内 容 可 以 给 网 站 使 用 者 不 同 的 和 实时 变化 的 内 容 ， 极 大 
地 提高 网 站 的 可 用 性 。 如 果 Web 应 用 都 只 是 使 用 静态 内 容 ， 则 Web 编程 完全 不 用 引入 PHP、JSP 
和 ASP 等 服务 器 端 脚本 语言 。 通 俗 地 说 ， 使 用 PHP 语言 的 主要 原因 之 一 ， 就 是 使 用 动态 内 容 。 

下 面 介绍 使 用 动态 内 容 的 案例 。 此 例 中 ， 在 先 不 涉及 变量 和 数据 类 型 的 情况 下 ， 将 使 用 PHP 
中 的 一 个 内 置 函 数 来 获得 动态 内 容 。 此 动态 内 容 就 是 使 用 date() 函 数 获得 Web 服务 器 的 时 间 。 

【 例 10.1】 实例 文件 :ch10\10.1.php) 

<HTML> 

<HEAD> 


<h2> 


PHP Tells time. - PHP 告诉 我 们 时 间 。 
</h2> 

</HEAD> 

<BODY> 


<?php date default timezone set ("PRC"); 
echo "现在 的 时 间 为 : "; 


echo date("H:i:s Y m d"); 


> 


</BODY> 
</HTML> 





PHP+ySQL 动态 网 站 开发 从 入 门 到 精通 (视频 教学 版 





运行 结果 如 图 10-1 所 示 。 过 一 段 时 间 再 次 运行 上 述 PHP 页 面 ， 即 可 看 到 显示 的 内 容 发 生 了 动 
态 的 变化 ， 如 图 10-2 所 示 。 














Oh/ocahes @ DP- CG ocdhon 
交 伯 (月 ”六 注 和 ”天 者 (V) 收藏 夫 (和 A) 工具 Im 帮助 H) 


PHP Tells time。 一 PHP 告 诉 我 们 时 间 。 


现在 的 时 间 为 : 13:24:25 2016 06 07 














由 - @ rapylecahos @ PD - o Blccalhost 
EEC 二 7 了 





























PHP Tells time. 一 PHP 告 诉 我 们 时 间 。 


现在 的 时 间 为 : 16:25:27 2016 06 07 





图 10-1 程序 运行 结果 图 10-2 时 间 发 生变 化 
【案例 分 析 】: 


(1) “PHP Tells time. - PHP 告诉 我 们 时 间 。” 是 HTML 中 的 "<HEAD><h2>PHP Tells time. - 
PHP 告诉 我 们 时 间 。</h2></HEAD>" 所 生成 的 。 后 面 的 “现在 的 时 间 为 : 13:24:26 2016 06 07” 是 
由 "<?php echo "现在 的 时 间 为 : echo date("H:is Y m d"); ?>" 生 成 的 。 

(2) 由 于 “现在 的 时 间 为 : 13:24:26 2016 06 07” 是 由 date( ) 函 数 动态 生成 并 且 实时 更 新 的 。 
如 果 再 次 打开 或 刷新 此 文件 ，PHP 代码 将 被 再 次 执行 ， 所 输出 的 时 间 也 会 发 生 改变 。 

(3) 此 实例 中 通过 date0 函 数 处 理 系 统 时 间 ， 得 到 动态 内 容 。 时 间 处 理 是 PHP 中 一 项 重要 的 
功能 。 


10.2 ”表单 与 PHP 


不 管 是 一 般 的 企业 网 站 还 是 复杂 的 网 络 应 用 ， 都 离 不 开 数 据 的 添加 。 通 过 PHP 服务 器 端 脚本 
语言 ， 程 序 可 以 处 理 那些 通过 浏览 器 对 Web 应 用 进行 数据 调用 或 添加 的 请 求 。 

回忆 一 下 平常 使 用 的 网 站 数据 输入 功能 ， 不 管 是 Web 邮箱 还 是 QQ 留言 ， 都 经 常 要 填 一 些 表 
格 ， 再 由 这 些 表格 把 数据 发 送出 去 。 而 完成 这 个 工作 的 部 件 就 是 “表单 (form) ”。 

虽然 表单 (form) 是 html 语言 的 东西 ， 但 是 PHP 与 form 变量 的 衔接 是 无 缘 的 。PHP 关心 的 
是 怎么 获得 和 使 用 form 中 的 数据 。 由 于 PHP 功能 强大 ， 可 以 很 轻松 地 对 它们 进行 处 理 。 

处 理 表单 数据 的 基本 过 程 是 : 数据 从 Web 表单 (form ) 发 送 到 PHP 代码 , 经 过 处 理 再 生成 html 
输出 。 它 的 处 理 原理 是 : 当 PHP 处 理 一 个 页 面 的 时 候 ， 会 检查 URL、 表 单数 据 、 上 传 文件 、 可 用 
cookie、Web 服务 器 和 环境 变量 , 如 果 有 可 用 信息 , 就 可 以 通过 PHP 访问 自动 全 局 变量 数组 $_GET、 
$_POST、$_FILES、$_COOKIE、$_SERVER 和 $_ENV 得 到 。 


10.3 ”表单 设计 


表单 是 一 个 比较 特殊 的 组 件 ， 在 html 中 有 着 比较 特殊 的 功能 与 结构 。 下 面 了 解 一 下 表单 的 基 
本 元 素 。 
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10.3.1 表单 基本 结构 


表单 的 基本 结构 是 由 <form></form> 标 识 包 右 的 区 域 ， 例 如 : 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action=" " method=" " enctype=" " > 
</form> 

</BODY> 

</HTML> 


其 中 ，<form > 标识 内 必须 包含 属性 。action 指定 数据 所 要 发 送 的 对 象 文件 ，method 指定 数据 














传输 的 方式 。 如 果 在 上 传 文件 等 操作 ， 还 要 定义 enctype 属性 以 指定 数据 类 型 。 
10.3.2 文本 框 


文本 框 是 form 输入 框 中 最 为 常见 的 。 下 面 通过 例子 讲述 文本 框 的 使 用 方法 。 
在 网 站 根 目录 下 创建 phpform 文件 夹 ， 然 后 在 其 下 创建 文件 formdemo.html， 文 件 代码 如 


<HTML> 

<HEAD> 

</HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 
<h3> 输 入 一 个 信息 〈 比 如 名 称 ): </h3> 
<input type="text" name="name" size="10" /> 

</form> 

</BODY> 

</HTML> 


加 在 phpform 文件 夹 下 创建 文件 formdemohandler.php， 文 件 代 码 如 下 。 


<?php 
$name = $_POST['name']; 
echo $name; 

> 





运行 formdemo.html， 结 果 如 图 10-3 所 示 。 


-Tee 
Oe ao scxjsc 











EX 了】 
输入 一 个 信息 《比如 名 称 ) : 
1 








图 10-3 程序 运行 结果 
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【案例 分 析 】: 


(1) <input type="text" name="name" size="10" 广 语 句 定义 了 form 的 文本 框 。 定 义 一 个 输入 框 
为 文本 框 的 必要 因素 为 : 


<input type="text" ...... /> 


其 他 的 属性 则 如 实例 中 一 样 ， 可 以 定义 文本 框 的 name 属性 ， 以 确认 此 文本 框 的 唯一 性 ， 定 义 
size 属性 以 确认 此 文本 框 的 长 度 。 
(2) 在 formdemohandler.php 文件 中 ， 则 使 文本 框 的 name 值 为 mame'。 


10.3.3 ”选项 框 
复 选 框 可 用 于 选择 一 项 或 者 多 项 。 通 过 修改 formdemo 的 例子 加 以 说 明 ， 具 体操 作 如 下 。 
在 phpform 文件 夹 下 修改 文件 formdemo.html 为 如 下 代码 。 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 
<h3> 输 入 一 个 信息 比如 名 称 ): </h3> 
<input type="text" name="name" size="10" /> 
<h3> 确 认 此 项 (可 复 选 ); </h3> 


<input type="checkbox" name="achecked" checked="checked" value="1" /> 





选择 此 项 传递 的 A 项 的 value 值 。 
<input type="checkbox" name="bchecked" value="2" /> 
选择 此 项 传递 的 B 项 的 value 值 。 
<input type="checkbox" name="cchecked" value="3" /> 
选择 此 项 传递 的 C 项 的 value 值 。 
</form> 
</BODY> 
</HTML> 
贺 在 phpform 文件 夹 下 修改 文件 formdemohandler.php， 其 代码 如 下 。 
<?php 


Sname = $_POST['name']; 

if(isset($ POST['achecked'])){ 
$achecked = $_POST['achecked']; 

了 

if(isset($ POST['bchecked'])){ 

$bchecked = $_POST['bchecked']; 

} 

if(isset($ POST['cchecked'])){ 

$cchecked = $_POST['cchecked']; 

} 

$aradio = $_POST['aradio']; 
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$aselect = $ POST['aselect']; 
echo $name."<br />"; 


if(isset ($achecked) and $achecked == 1){ 

echo "选项 A 的 value 值 已 经 被 正确 传递 。<br />"; 
}elsef{ 

echo "选项 A 没有 被 选择 ， 其 value 值 没有 被 传递 。<br />"; 
1 
if(isset ($bchecked) and $bchecked == 2){ 

echo "选项 B 的 value 值 已 经 被 正确 传递 。<br />"; 
}elsef{ 

echo "选项 B 没有 被 选择 ， 其 value 值 没 有 被 传递 。<br />"; 
} 
if(isset ($cchecked) and $cchecked == 3){ 

echo "选项 C 的 value 值 已 经 被 正确 传递 。<br />"; 
}else{ 

echo "选项 C 没有 被 选择 ， 其 value 值 没 有 被 传递 。<br />"; 
} 


?> 


贺 运行 formdemo.html， 结 果 如 图 10-4 所 示 。 
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图 10-4 程序 运行 结果 
【案例 分 析 】 


(1) <input type="checkbox" name="achecked" checked="checked" value="1" /> 语句 定义 了 复 选 
框 。 定 义 一 个 input 标识 为 复 选 框 时 需 指定 类 型 为 checkbox: 


<input type="checkbox" .… /> 
定义 为 复 选 框 之 后 ， 还 需要 定义 复 选 框 的 name 属性 ， 以 确定 在 服务 器 端 程序 的 唯一 性 ， 定 义 


value 属性 ， 以 确定 此 单 选项 所 要 传递 的 值 ， 定 义 Checked 属性 ， 以 确定 复 选 框 的 默认 状态 ， 若 为 
checked 则 默认 为 选择 ， 如 果 不 定义 此 项 ， 默 认为 不 选择 。 


(2) 在 formdemohandler.php 文件 中 ， 则 使 选项 的 name 值 为 'achecked'、name 值 为 'bchecked'、 
name 值 为 'cchecked' 并 且 根 据 value 值 作出 判断 。 

















10.3.4” 单 选 按钮 


下 面 通过 案例 来 介绍 如 何 使 用 单 选 按钮 ， 仍 然 通 过 修改 formdemo 的 例子 加 以 说 明 ， 具体 步骤 
如 下 。 


加 在 phpform 文件 夹 下 修改 文件 formdemo.html， 代 码 如 下 。 










贺 在 phpform 文件 夹 下 修改 文件 formdemohandler.php， 代 码 如 下 。 


运行 formdemo.html， 结 果 如 图 10-5 所 示 。 
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确认 此 项 (可 复 选 ) : 


回 选择 此 项 传递 的 硕 的 value 信 。 口 选择 此 项 全 北约 3 项 的 walve 入 。 
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图 10-5 程序 运行 结果 
【案例 分 析 】: 


(1) <input type="radio” name="aradio" value="al" /> 语句 定义 了 一 个 单 选 按钮 。 后 面 的 <input 
type="radio" name="aradio" value="a2" checked="checked" /> 和 <input type="radio" name="aradio" 
value="a3" /> 定义 了 另外 两 个 单 选 按钮 。 

定义 一 个 input 标识 为 单 选 按钮 时 需 指定 类 型 为 radio: 


<input type="radio" .… /> 


定义 为 单 选 按 钮 之 后 ， 还 需要 定义 单 选 按钮 的 name 属性 ， 以 确定 在 服务 器 端 程序 的 唯一 性 ; 
定义 value 属性 ， 以 确定 此 单 选 按钮 所 要 传递 的 值 ， 定 义 checked 属性 ， 以 确定 单 选 按钮 的 默认 状 
态 ， 若 为 checked 则 默认 为 选择 ， 如 果 不 定 义 此 项 ， 默 认为 不 选择 。 

(2) 在 formdemohandler.php 文件 中 ， 则 使 单 选 按钮 的 name 值 为 "aradio"， 然 后 证 语句 通过 
对 aradio 传递 的 不 同 的 值 作出 判断 ， 打 印 不 同 的 值 。 


10.3.5 下 拉 列 表 


下 面 通过 实例 来 介绍 下 拉 列 表 的 使 用 方法 和 技巧 ， 仍 然 通过 修改 formdemo 的 例子 加 以 说 明 ， 
具体 步骤 如 下 。 


加 在 phpform 文件 夹 下 修改 文件 formdemo.html， 添 加 代码 如 下 。 
<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 


<h3> 在 下 拉 菜 单 中 选择 一 项 : </h3> 
<select name="aselect" Size="1"> 
<option value="hainan"> 海 南 </option> 
<option value="qingdao"” selected> 青 岛 </option> 
<option value="beijing"> 北 京 </option> 
<option value="xizang"> 西 藏 </option> 
</select> 
</form> 
</BODY> 
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i 
在 phpform 文件 夹 下 修改 文件 formdemohandler.php， 代 码 如 下 。 





运行 formdemo.html， 结 果 如 图 10-6 所 示 。 
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日 迁 症 此 硕 伟 谤 的 C 项 的 valus 信 ， 


单 选 一 项 : 
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10-6 程序 运行 结果 
【案例 分 析 】: 


(1) 下 拉 列 表 是 通过 <select></selec 亿 标识 表示 的 。 而 下 拉 列 表 当 中 的 选项 是 通过 包含 在 其 中 
的 <option></option> 标 识 表示 的 。<select> 标 识 中 name 定义 下 拉 列 表 的 name 属性 ， 以 确认 它 的 唯 
一 性 。<option> 标 识 中 value 定义 需要 传递 的 值 。 

(2) 在 formdemohandler.php 文件 中 , 则 使 选项 的 name 值 为 "aselect"。 然 后 让 语句 通过 对 aselect 
传递 的 不 同 的 值 做 出 判断 ， 打 印 不 同 的 值 。 
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10.3.6 ” 重 置 按钮 


重 置 按 钮 用 来 重 置 所 有 的 表单 输入 的 数据 。 对 于 重 置 按 钮 的 使 用 ， 仍 然 通 过 修改 formdemo 的 
例子 加 以 说 明 ， 具 体 步 骤 如 下 。 


在 文件 夹 下 修改 文件 formdemo html， 代 码 如 下 。 


<HTML> 
<HEAD></HEAD> 
<BODY> 
<form action="formdemohandler.php" method="post"> 
<h3> 点 击 此 按钮 重 置 所 有 信息 : </h3> 
<input type="RESET" value=" 重 署 "> 
</form> 
</BODY> 
</HTML> 


贺 运行 formdemo.html， 结 果 如 图 10-7 所 示 。 
贺 点 击 “ 重 置 ”按钮 ， 页 面 中 所 有 输入 数据 被 重 置 为 默认 值 ， 如 图 10-8 所 示 。 
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图 10-7 程序 运行 结果 图 10-8 重 置 为 默认 值 


由 <input type="RESET" value=" 重 置 "> 语句 可 见 ， 重 置 按钮 是 <input /> 标识 的 一 种 。 定 义 一 个 
input 标识 为 单 选项 的 必要 因素 为 : 


<input type="reset" ..... /> 
Value 属性 是 按钮 所 显示 的 字符 。 
10.3.7 ”提交 按钮 


到 现在 为 止 ,上 面 程序 中 form 中 的 所 有 元 素 都 已 经 设置 完成 , 并 且 在 相应 的 PHP 文件 中 做 了 
处 理 。 这 个 时 候 ， 要 想 把 HTML 页 面 中 所 有 的 数据 发 送出 去 给 相应 PHP 文件 进行 处 理 ， 就 需要 使 
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用 submit 按钮 ， 也 就 是 “提交 ”按钮 。 下 面 添加 “提交 ”按钮 ， 并 且 提 交 数 据 。 具 体 步骤 如 下 。 
在 phpform 文件 夹 下 修改 文件 formdemo.html， 最 终 代 码 如 下 。 


<HTML> 

<HEAD></HEAD> 

<BODY> 

<form action="formdemohandler.php" method="post"> 
<h3> 输 入 一 个 信息 (比如 名 称 ): </h3> 
<input type="text" name="name" size="10" /> 
<h3> 确 认 此 项 (可 复 选 ): </h3> 


<input type="checkbox" name="achecked" checked="checked" value="1" /> 


选择 此 项 传递 的 A 项 的 value 值 。 
<input type="checkbox" name="bchecked" value="2" /> 
选择 此 项 传递 的 B 项 的 value 值 。 
<input type="checkbox" name="cchecked" value="3" /> 
选择 此 项 传递 的 C 项 的 value 值 。 

<h3> 单 选 一 项 : </h3> 

<input type="radio" name="aradio" value="al" /> 蓝天 





<input type="radio" name="aradio" value="a2" checked="checked" /> 白云 
<input type="radio" name="aradio" value="a3" /> 大 海 
<h3> 在 下 拉 菜 单 中 选择 一 项 ， </h3> 
<select name="aselect" size="1"> 
<option value="hainan"> 海 南 </option> 
<option value="qingdao"” selected> 青 岛 </option> 
<option value="beijing"> 北 京 </option> 
<option value="xizang"> 西 藏 </option> 
</select> 
<h3> 点 击 此 按钮 重 置 所 有 信息 : </h3> 
<input type="RESET" value=" 重 署 " /> 
<h3> 点 击 此 按钮 提交 所 有 信息 到 formdemohandler .php 文件 : </h3> 
<input type="submit" value=" 提 交 "” /> 
</form> 
</BODY> 
</HTML> 


贺 在 phpform 文件 夹 下 修改 文件 formdemohandler.php， 其 最 终 代 码 如 下 。 


<?php 
Sname = $_ POST['name']; 
if(isset($ POST['achecked'])){ 

$achecked = $_POST['achecked']; 

} 
if(isset($ POST['bchecked'])){ 
$bchecked = $_POST['bchecked']; 
站 
if(isset($ POST['cchecked'])){ 


运行 formdemo.html， 结 果 如 图 10-9 所 示 。 
单 击 “ 提 交 ” 按 钮 ， 页 面 跳 转 到 formdemohandler.php， 输 出 结果 如 图 10-10 所 示 。 
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图 10-9 程序 运行 结果 图 10-10 ”提交 数据 


10.4 传递 数据 的 两 种 方法 
数据 传递 的 常用 方法 有 POST 和 GET 两 种 ， 下 面 来 介绍 这 两 种 方法 的 使 用 技巧 。 
10.4.1 用 POST 方式 传递 数据 


表单 (Form) 传递 数据 是 通过 POST 和 GET 两 种 方式 进行 的 。 在 定义 表单 属性 的 时 候 ， 要 在 
method 属性 上 定义 使 用 哪 种 数据 传递 方式 。 

<form action="URI" method="post"> 定 义 了 表单 在 把 数据 传递 给 目标 文件 的 时 候 ， 使 用 的 是 
POST 方式 。<form action="URI" method="get"> 则 定义 了 表单 在 把 数据 传递 给 目标 文件 的 时 候 ， 使 
用 的 是 GET 方式 。 

POST 是 比较 常见 的 表单 提交 方式 。 通 过 POST 方式 提交 的 变量 , 不 受 特定 的 变量 大 小 的 限制 ， 
并 且 被 传递 的 变量 不 会 在 浏览 器 地 址 栏 里 以 URL 的 方式 显示 出 来 。 


10.4.2 用 GET 方式 传递 数据 


GET 方式 比较 有 特点 。 通 过 GET 方式 提交 的 变量 有 大 小 限制 ， 不 能 超过 100 个 字符 。 它 的 变 
量 名 和 与 之 相对 应 的 变量 值 都 会 以 URL 的 方式 显示 在 浏览 器 地 址 栏 里 。 所 以 ， 若 传递 大 而 敏感 的 
数据 ， 一 般 不 使 用 此 方式 。 

使 用 GET 方式 传递 数据 ， 通 常 使 用 URL 连接 来 进行 的 。 

下 面 对 此 操作 进行 讲解 ， 具 体 步骤 如 下 。 

在 网 站 根 目 录 下 建立 getparam.php 文件 ， 输 入 以 下 代码 并 保存 。 

<?php 

HEISEGED Iau) 

上 

echo “参数 还 没有 输入 。 ' 7 


}else{ 
$user=$_GET['u']; 


"188 
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Switch ($user){ 

Case 1: 
echo "用 户 是 王小明 "; 
break; 

case 2: 
echo "用 户 是 李 丽 丽 "; 


break; 


有 


?> 


在 浏览 器 地 址 栏 中 输入 “http://localhost/getparam.php?u”， 并 按 回 车 键 确认 ， 运 行 结果 如 


图 10-11 所 示 。 


在 浏览 器 地 址 栏 中 输入 “http://localhost/getparam.php?u=1”， 并 按 回 车 键 确认 ， 运 行 结果 


如 图 10-12 所 示 。 
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参数 还 没有 输入 。 





图 10-11 程序 运行 结果 


文件 (站 ”编辑 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 













文件 (站 ” 编 名 (E) 各 看) 收藏 只 (A) 工具 (T) 。 帮助 (H) 
用 户 是 王小明 


图 10-12 程序 运行 结果 


在 浏览 器 地 址 栏 中 输入 “http://localhost/getparam.php?u=2”， 并 按 回 车 键 确认 ,运行 结果 


如 图 10-13 所 示 。 
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文件 (办 名 (E) ”前 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


用 户 是 李 丽 丽 





【案例 分 析 】: 


(1) 在 URL 中 GET 方式 通过 “? 
(2) 对 元 素 赋值 ， 使 用 “=” 号 。 





图 10-13 程序 运行 结果 


”号 后 面 的 数组 元 素 的 键 名 (这 里 是 “u”) 来 获得 元 素 值 。 


(3) switch 条 件 语 句 做 出 判断 并 返回 结果 。 
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10.5 ”PHP 获取 表单 传递 数据 的 方法 


如 果 表 单 使 用 POST 方式 传递 数据 ， 则 PHP 要 使 用 全 局 变量 数组 $ POST[] 来 读 取 所 传递 的 数 
据 。 

表单 中 元 素 传递 数据 给 $_POST[D] 全 局 变量 数组 ， 其 数据 以 关联 数组 中 的 数组 元 素 形式 存在 。 
以 表单 元 素 的 名 称 属性 为 键 名 ， 以 表单 元 素 的 输入 数据 或 传递 的 数据 为 键 值 。 

比如 前 面 formdemohandler.php 文件 中 Sname =$_POST[mame']: 语 句 就 是 读 取 名 为 name 的 文本 
框 中 的 数据 。 此 数据 以 name 为 键 名 ， 以 文本 框 输入 的 数据 为 键 值 。 

再 如 $achecked = $_POST['achecked] 语 句 ， 读 取 名 为 achecked 的 复 选 框 传递 的 数据 。 此 数据 以 
achecked 为 键 名 ， 以 复 选 框 传递 的 数据 为 键 值 。 

如 果 表 单 使 用 GET 方式 传递 数据 , 则 PHP 要 使 用 全 局 变量 数组 $_GET[] 来 读 取 所 传递 的 数据 。 
与 $_POST[] 相 同 ， 表单 中 元 素 传递 数据 给 $_GET[] 全 局 变量 数组 ， 其 数据 以 关联 数组 中 的 数组 元 素 
形式 存在 。 以 表单 元 素 的 名 称 属性 为 键 名 ， 以 表单 元 素 的 输入 数据 或 是 传递 的 数据 为 键 值 。 


10.6 PHP 对 URL 传递 的 参数 进行 编码 


PHP 对 URL 中 传递 的 参数 进行 编码 ， 一 可 以 实现 对 所 传递 数据 的 加 密 ， 二 可 以 对 无 法 通过 浏 
览 器 传递 的 字符 进行 传递 。 要 实现 此 操作 一 般 使 用 urlencode0 和 rawurlencode0 函 数 。 而 对 此 过 程 
的 反 向 操作 就 是 使 用 urldecode0 和 rawurldecode() 函 数 。 

下 面 对 此 操作 进行 讲解 ， 具 体 步 又 如 下 。 

加 在 网 站 根 目录 下 建立 urlencode.php 文件 ， 输 入 以 下 代码 并 保存 。 

<?php 

$user = ' 王 小 明 刘 晓 莉 ' ; // 定 义 变量 

$linkl = "index.php?userid=".urlencode ($user)."<br />"; // 对 字符 串 进行 编码 

$link2 = "index.php?userid=".rawurlencode ($user) ."<br />"; // 对 字符 串 进行 编码 

echo $linkl.$link2; 

// 对 编码 的 反 向 操作 

echo urldecode ($1link1); 

echo urldecode ($1link2); 


echo rawurldecode ($1link2); 
了 3 


加 在 浏览 器 地 址 栏 中 输入 “http://localhost/urlencode.php”， 并 按 回 车 键 确认 ， 运 行 结果 如 
图 10-14 所 示 。 

















[< 加 划 raryWoc- @ Pp- cx| iocalhost 


文件 (者 岛 (E) 二 看 WV) 收 大夫 (A) 工具 (7) 大 s(H) 














Php ?useri d=¥CDWF SXDOXA1XC3AF T+XC1%F SSCPXFENCONF2 
i 5XDOXAI1XC3XFT%20MC1XFS%CFXFE%COXF2 


php?useri 寺 王小明 刘 晓 有 有 





图 10-14 ”程序 运行 结果 
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【案例 分 析 】 : 

(1) 在 $linkl 变量 的 赋值 中 ， 使 用 urlencode0 函 数 对 一 个 中 文字 符 串 Suser 进行 编码 。 

(2) 在 $link2 变量 的 赋值 中 ， 使 用 rawurlencode() 函 数 对 一 个 中 文字 符 串 $user 进行 编码 。 

(3) 这 两 种 编码 方式 的 区 别 在 于 对 空格 的 处 理 ，urlencode() 函 数 将 空格 编码 为 “+” 号 ， 而 
rawurlencode() 函 数 将 空格 编码 为 “%20” 加 以 表述 。 

(4) urldecode() 函 数 实现 对 编码 的 反 向 操作 。 


10.7 ”实战 演练 一 一 PHP 与 Web 表单 的 综合 应 用 


下 面 进行 处 理 表单 数据 的 讲解 。 此 实例 将 假设 一 名 网 络 浏览 者 在 某 酒店 网 站 上 登记 房间 。 具 
体 步 骤 如 下 。 
在 网 站 根 目录 下 建立 一 个 html 文件 form.html， 输 入 以 下 代码 并 保存 。 


<HTML> 

<HEAD><h2>GoodHome online booking form. - GoodHome 在 线 订 房 表 。</h2></HEAD> 
<BODY> 

<form action="formhandler.php" method="post"> 

<table> 


<tr bgcolor="#3399FF"> 
<td> 客 人 姓名 :</td> 
<td><input type="text" name="customername" size="10" /></td> 
</tr> 
<tr bgcolor="#CCCCCC" > 
<td> 到 达 时 间 :</td> 
<td><input type="text" name="arrivaltime" size="3" /> 天 内 </td> 
</tr> 
<tr bgcolor="#3399FF" > 
<td> 联 系 电 话 :</td> 
<td><input type="text" name="phone" size="15" /></td> 
</tr> 
<tr bgcolor="#666666" > 
<td align="center"><input type="submit" value=" 确 认 订 房 信 息 "”/></td> 
</tr> 
</table> 
</form> 
</BODY> 
</HTML> 


加 在 浏览 器 地 址 栏 中 输入 “http://localhostform.html”, 并 按 回 车 键 确认 , 运行 结果 如 图 10-15 
所 示 . 
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图 10-15 程序 运行 结果 
加 在 相同 目录 下 建立 一 个 PHP 文件 formhandler.php， 输 入 以 下 代码 并 保存 。 


<HTML> 
<HEAD> 

<H2>GoodHome booking info. - GoodHome 订房 表 确认 信息 。</H2> 
</HEAD> 

<BODY> 


<?php 
$customername = $_POST['customername']; 


$arrivaltime = $ POST['arrivaltime']; 
$phone = $_POST['phone']; 


echo '<p> 订 房 确认 信息 :</p>"'; 
echo ' 客 人 '.$customername.' 您 将 会 在 ' .$arrivaltime.' 内 到 达 。 您 的 联系 电话 是 
"Spione ue ts 
人 
</BODY> 
</HTML> 


回 到 浏览 器 中 打开 的 form.html 页 面 。 在 表单 中 输入 数据 ，【 客 人 姓名 】 为 “王小明 ”、 
【到 达 时 间 】 为 “3”、【 联 系 电话 〗 为 “1359XXXX377”， 单 击 【确认 订房 信息 】 按 钮 ， 浏 览 
器 会 自动 跳 转 到 formhandler.php 页 面 ， 显 示 结 果 如 图 10-16 所 示 。 


(Sie D- BCx| 人 ceahos x A 


文件 (有 辣 唱 E) 查看 (V) 要 吉 闪 A) 工具 Mm 芭 翅 HH) 





























GoodHome booking info。- GoodHome 订 房 表 确 认 信息 。 


订房 确认 信息 : 
客人 王小明 ， 您 将 会 在 3 天 内 到 达 。 您 的 联系 电话 是 135900003T7。 





| -| 
懂 100% ~ 














图 10-16 程序 运行 结果 
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【案例 分 析 】 : 


(1) 在 form.html 中 form 通过 POST 方法 Cmethod) 把 3 个 <input type="text" ... /> 中 
的 文本 数据 发 送 给 formhandler.php。 

(2) 在 formhandler.php 中 , 代码 通过 读 取 数组 $ POST 中 的 具体 变量 $ POST['customername']、 
$_POST[arrivaltime] 和 $_POST['phone]， 把 它 赋 值 给 本 地 变量 $customername 、$arrivaltime 和 
$phone。 然 后 ， 通 过 echo 命令 使 用 本 地 变量 ， 把 信息 生成 html 后 输出 给 浏览 器 。 

(3) 要 提 到 的 是 "echo ' 客 人 ' .$customername.'， 您 将 会 在 ' .$arrivaltime.' 天 
内 到 达 。 您 的 联系 电话 是 ' . $phone.'。';" 中 的 “.” 是 字符 串 连 接 操作 符 ， 它 把 不 同 部 分 的 
字符 串 连接 在 一 起 。 在 使 用 echo 命令 的 时 候 经 常会 用 到 它 。 


10.8 高 手 私房 菜 


技巧 1: 使 用 urlencode() 和 rawurlencode() 函 数 需要 注意 什么 ? 

如 果 配 合 JS 处 理 页 面 的 信息 的 话 ， 要 注意 urlencode() 函 数 使 用 后 ，“+” 号 与 JS 的 冲突 。 由 
于 JS 中 “+” 号 是 字符 串 类 型 的 连接 操作 符 。JS 在 处 理 URL 时 就 无 法 识别 其 中 的 “+” 号 。 这 时 
可 以 使 用 rawurlencode() 函 数 对 其 进行 处 理 。 


技巧 2: 理解 GET 和 POST 的 区 别 和 联系 。 


两 者 的 区 别 与 联系 如 下 。 
(1) POST 是 向 服务 器 传送 数据 ，GET 是 从 服务 器 上 获取 数据 。 
(2) POST 是 通过 HTTP POST 机 制 ， 将 表单 内 各 个 字段 与 其 内 容 放置 在 HTML HEADER 中 
一 起 传送 到 ACTION 属性 所 指 的 URL 地 址 。 用 户 看 不 到 这 个 过 程 ; GET 是 把 参数 数据 队列 添加 到 
提交 表单 的 ACTION 属性 所 指 的 URL 中 ， 值 和 表单 内 各 个 字段 一 一 对 应 ， 在 URL 中 可 以 看 到 。 
(3) 对 于 GET 方式 ， 服 务 器 端 用 Request.QueryString 获取 变量 的 值 ， 对 于 POST 方式 ， 服 务 
器 端 用 RequestForm 获取 提交 的 数据 。 
(4) POST 传送 的 数据 量 较 大 ， 一 般 被 默认 为 不 受 限 制 。 但 理论 上 ，IIS4 中 最 大 量 为 80KB， 
IIS5 中 为 100KB; GET 传送 的 数据 量 较 小 ， 不 能 大 于 2KB。 
(5) POST 安全 性 较 高 ，GET 安全 性 非常 低 ， 但 是 执行 效率 却 比 POST 方法 好 。 
(6) 在 做 数据 添加 、 修 改 或 删除 时 ， 建 议 用 POST 方式 ， 而 在 做 数据 查询 时 ， 建 议 用 GET 方式 。 
(7) 机 密 信息 的 数据 ， 建 议 用 POST 数据 提交 方式 。 


10.9 经典 习题 


(1) 制作 一 个 包含 各 种 表单 元 素 注 册 表 的 例子 。 

(2) 制作 两 个 传递 数据 方式 的 例子 ， 并 分 析 它 们 的 区 别 。 
(3) 制作 一 个 PHP 获取 表单 数据 的 例子 。 

(4) 制作 一 个 PHP 对 URL 传递 参数 进行 编码 的 例子 。 





第 11 章 PHP 文件 与 目录 操作 


前 面 的 章节 中 ， 已 经 实现 了 用 form 发 送 数据 给 PHP，PHP 再 处 理 数 据 并 输出 html 给 浏览 器 。 
在 这 样 的 流程 里 ， 数 据 会 直接 被 PHP 代码 处 理 成 html。 如 果 想 把 数据 存储 起 来 ， 并 在 需要 的 时 候 
读 取 和 处 理 ， 该 怎么 办 呢 ? 这 就 是 本 章 需 要 解决 的 问题 。 在 PHP 开发 网 站 的 过 程 中 ， 文 件 的 操作 
大 致 分 为 对 普通 文件 的 操作 和 对 数据 库 文 件 的 操作 。 本 章 主要 讲述 如 何 对 普通 文件 进行 写 入 和 读 
取 、 目 录 的 操作 、 文 件 的 上 传 等 操作 。 


本 章 学 习 目 标 


掌握 文件 的 基本 操作 方法 
掌握 目录 的 操作 方法 

掌握 文件 的 上 传 方法 

掌握 访客 计算 器 的 制作 方法 


11.1 文件 操作 


在 不 使 用 数据 库 系 统 的 情况 下 ， 数 据 可 以 通过 文件 〈file) 来 实现 数据 的 存储 和 读 取 。 这 个 数 
据 存 取 的 过 程 也 是 PHP 处 理 文件 的 过 程 。 这 里 涉及 的 文件 是 文本 文件 (text file) 。 


11.1.1 文件 数据 的 写 入 
对 于 一 个 文件 的 “ 读 ”或 “ 写 ” 操 作 ， 基 本 步 又 如 下 : 


打开 文件 。 

园 从 文件 里 读 取 数据 ， 或 者 向 文件 内 写 入 数据 。 

辆 关闭 文件 . 

打开 文件 的 前 提 是 ， 文 件 首先 是 存在 的 。 如 果 不 存在 ， 则 需要 建立 一 个 文件 ， 并 且 在 所 在 的 
系统 环境 中 ， 代 码 应 该 对 文件 具有 “ 读 ” 或 “ 写 ” 的 权限 。 

以 下 实例 介绍 PHP 如 何 处 理 文 件数 据 。 在 这 个 实例 中 需要 把 客人 订房 填写 的 信息 保存 到 文件 
中 ， 以 便 以 后 使 用 。 

【 例 11.1】〔 实 例文 件 : chl1\11.1.php 和 11.1.1.php) 

在 PHP 文件 同 目录 下 建立 一 个 名 称 为 booked.txt 的 文本 文件 ， 然 后 创建 11.1.php， 写 入 
代码 如 下 。 

<!DOCTYPE html PUBLIC "-//W3C/ /DTD XHTML .0 Transitional//EN" 


"http://www.w3.0rg/TR/xhtml1/ DTD/xhtmll-transitional.dtd"> 
<html xmlns="http://www.w3.0org/1999/xhtml"> 
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<HEAD><meta http-equiv="Content-Type" content="text/html; charset=gb2312" 


/><h2>GoodHome 在 线 订房 表 (文件 存储 )。</h2></HEAD> 
<BODY> 


<form action="11.2.php" method="post"> 
<table> 
<tr bgcolor="#3399FF" > 

<td> 客 户 姓名 :</td> 


<td><input type="text" name="customername" size="20" /></td> 
</tr> 


<tr bgcolor="#CCCCCC" > 
<td> 客 户 性 别 : </td> 
<td> 
<select name="gender"> 
<option value="m"> 男 </option> 
<option value="f"> 女 </option> 
</select> 
</td> 
= 
<tr bgcolor="#3399FF" > 
<td> 到 达 时 间 :</td> 
<td> 
<select name="arrivaltime"> 
<option > 一 天 后 </option> 
<option 2"> 两 天 后 </option> 
<option value="3"> 三 天 后 </option> 











<option > 四 天 后 </option> 
<option value="5"> 五 天 后 </option> 
</select> 
</td> 
</tr> 
<tr bgcolor="#CCCCCC" > 


<td> 电 话 :</td> 

<td><input type="text" name="phone" size="20" /></td> 
jz 
<tr bgcolor="#3399FF" > 

<td>email:</td> 

<td><input type="text" name="email" size="30" /></td> 
</tr> 
<tr bgcolor="#666666" > 

<td align="center"><input type="submit" value=" 确 认 订 房 信 息 "” /></td> 
</tr> 
</table> 
</form> 
</BODY> 
</HTML> 


贺 在 11.1.php 文件 的 同 目录 下 创建 11.2.php 文件 ， 代 码 如 下 。 


<html> 
<head> 
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<title> </title> 

</head> 

<body> 

<?php 

$DOCUMENT ROOT = $_SERVER['"'DOCUMENT ROOT']; 
$customername = trim($ POST['customername']); 
$gender = $_ POST['gender']; 

$arrivaltime = $ POST['arrivaltime']; 

$phone = trim($ POST['phone']); 


$email = trim($ POST['email']); 
if( S$gender == "m"){ 
$customer = "先生 "7 
}else{ 
Soustomer = 上" 


} 


$date = date("H:i:s Y m d"); 
$string to be added = S$date."\t".$customername."\t".$customer." 将 在 
".$arrivaltime." 天 后 到 达 \t 联系 电话 : ".$Sphone."\t Email: ".S$email ."\n"; 
$fp = fopen("$DOCUMENT ROOT/booked.txt",'ab'); 
if(fwrite($fp, $string to be added, strlen($string to be added))){ 
echo $customername."\t".$customer." ,您 的 订房 信息 已 经 保存 。 我 们 会 通过 email 和 电 
话 和 您 联系 。"; 
}else{ 
echo "信息 存储 出 现 错误 。"; 
外 
fclose ($fp); 
> 
</body> 
</html> 


园 运行 11.1.php 文件 ， 最 终 效果 如 图 11-1 所 示 。 
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图 11-1 程序 运行 效果 


在 表单 中 输入 数据 ，【 客 户 姓名 】 为 “ 李 莉 痢 ”、【〖【 到 达 时 间 】 为 “三 天 后 ”、【 电 话 】 
为 “159XXXXX266”。 单 击 【 确 认 订房 信息 】 按 钮 ， 浏 览 器 会 自动 跳 转 到 formfilehandler.php 页 
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面 ， 并 且 同 时 会 把 数据 写 入 booked.txt。 如 果 之 前 没有 创建 booked.txt 文件 ，PHP 会 自动 创建 。 运 
行 结果 如 图 11-2 所 示 。 











敬 hapyiloc- 和 P - BCX| localhost 
文件 (篇 霹 (E) 。 坦 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 














李 莉 莉 女士 ,您 的 订房 信息 已 经 保存 。 我 们 会 通过 Email 和 
电话 和 您 联系 。 








图 11-2 程序 运行 结果 


连续 写 入 几 次 不 同 的 数据 ， 都 会 被 保存 到 booked.txt 中 。 用 写字 板 打 开 booked.txt， 运 行 结 果 
如 图 11-3 所 示 。 


文 作 ( 检 B(O)_ 喜 看 帮助 (H) 

06:23:16 2016 01 06 地 用 用 女 上 将 在 3 太后 到 达 。 联系 电话 :159XXXXX266 :11118hormail, cam 
06:25:41 2016 01 06 方芳 芳 女士 将 在 5 天 后 到 达 。 联系 电话 ，136XXXXX253 3 fangfangfangahotlail con 
06:26:26 2016 01 06 王小明 先生 将 在 2 天 后 到 达 ”联系 电话 ，1359XXXXX377 + wangxiaoning@hotnail, com 
06:27:28 2016 01 06 赵 大 勇 先生 将 在 4 天 后 到 达 。 联系 电话 ，1389XXXXX399 :zhaodayong@hotnail. com 











和 菇 1 行 , 魏 4 列 


图 11-3 打开 booked.txt 
【案例 分 析 】: 


(1) 其 中 ，$DOCUMENT_ROOT =$_SERVER['DOCUMENT_ROOT']; 通过 使 用 超 全 局 数组 
$_SERVER 来 确定 本 系统 文件 根 目 录 。 在 Windows 桌面 开发 环境 中 的 目录 是 c:/wamp/www/。 

(2 ) $customername 、 S$arrivaltime 、 $phone 为 form4file.html 通过 POST 方法 给 
formfilehandler.php 传递 的 数据 。 

(3) $date 为 用 date() 函 数 处 理 的 写 入 信息 时 的 系统 时 间 。 

(4) $string_to_be_added 是 要 写 入 booked.txt 文 件 的 字符 串 数据 , 它 的 格式 是 通过 “Yt” 和 “\n” 
完成 的 。“\t” 是 tabb，“\n” 是 换 新 行 。 

(5) $fp = fopen("$DOCUMENT_ROOT/booked.txt",'ab"); 是 fopen( ) 函 数 打开 文件 并 赋值 给 变 
量 $fp。fopen( ) 函 数 的 格式 是 fopen("Path", "Parameter")。 其 中 ，"$SDOCUMENT_ ROOT/booked.txt" 
就 是 路 径 (Path ) ， 而 'ab' 是 参数 (Parameter) 。'ab' 中 的 a 是 指 在 原 有 文件 上 继续 写 入 数据 ，b 则 是 
规定 了 写 入 的 数据 是 二 进 制 binary) 的 数据 模式 。 

(6)fwrite($fp, $string to_be_added, strlen($string to_be_added)); 是 对 已 经 打开 的 文件 进行 写 入 
操作 。strlen($string to_be_added) 是 通过 strlen() 函 数 给 出 所 要 写 入 字符 串 数据 的 长 度 。 


(7) 在 写 入 操作 完成 之 后 ， 用 felose() 函 数 关 闭 文件 。 
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11.1.2 ”文件 数据 的 读 取 


到 目前 为 止 ， 数 据 写 入 到 了 文件 中 ， 而 且 文件 也 可 以 直接 被 打开 ， 以 查看 数据 ， 并 对 数据 进 
行 其 他 操作 。 但 是 ， 学 习 PHP 的 一 个 重要 目的 ， 是 要 通过 浏览 器 对 数据 进行 读 取 和 使 用 。 那 么 如 
何 读 取 数 据 并 且 通 过 浏览 器 进行 展示 呢 ? 

下 面 通过 实例 对 文件 数据 的 读 取 进行 了 解 。 

【 例 11.2】〔 实 例文 件 ，ch11\11.3.php) 

<?php 

/ /确认 文件 路 径 

$DOCUMENT ROOT = $_SERVER['DOCUMENT ROOT']; 

// 确 认 文 件 是 否 存在 

@$fp = fopen("$DOCUMENT ROOT/booked.txt",'rb'); 

if(!$fp) { 

echo "没有 订房 信息 。"; 
exit; 

/ /循环 输 出 文件 内 容 

while (!feof($fp)){ 

S$order = fgets($fp, 2048); 
echo $order. "<br />"; 

} 

fclose ($fp); // 关 闭 文件 


之 


运行 结果 如 图 11-4 所 示 。 


[¢ 轿 车 htpyoc. @ PD 8cx| locahost 


文件 (月 ”编辑 (E) 。 坦 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 
































06:23:16 2016 05 06 李 莉 莉 女士 将 在 3 天 后 到 达 。 联系 电话 ，159XXXXX266 : 1ilili@hotnail. con 
06:25:41 2016 05 06 方芳 芳 女士 将 在 5 天 后 到 达 联系 电话 ，136XXXXX253 : fangfangfang@hotnail, con 


06:26;26 2016 05 06 王小明 先生 将 在 2 天 后 到 达 联系 电话 ，1359XXXXX377 : wangxiaoning@hotnail. con 
06:27:28 2016 05 06 起 大 勇 先生 将 在 4 天 后 到 达 联系 电话 ，1389XXXXX399 : zhaodayone@hotnail, con 








图 11-4 程序 运行 结果 

【案例 分 析 】: 

(1) SDOCUMENT_ROOT =$_SERVER['DOCUMENT_ROOT']; 确 认 文件 位 置 。 

(2) fopen() 通 过 参数 rb 打开 booked.txt 文件 进行 二 进 制 读 取 。 读 取 内 容 赋值 给 变量 $ 中 。$fp 
前 的 @ 符 号 用 来 排除 错误 提示 。 

(3) 让 语句 表示 ， 如 果 变 量 $fp 为 空 ， 则 显示 “没有 订房 信息 。” 且 退出 。 

(4) While 循环 中 ，!feof($fp) 表 示 只 要 不 到 文件 尾 ， 就 继续 while 循环 。 循 环 中 fgets() 读 取 变 
量 $fp 中 的 内 容 并 赋值 给 $order。 
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(5) fgets() 中 2048 的 参数 表示 允许 读 取 的 最 长 字 节 数 为 2048-1=2047 字 节 。 

(6) 最 后 felose() 关 闭 文件 。 

不 管 是 读 文件 还 是 写 文件 ,其 实 文件 在 用 fopen 打开 的 时 候 就 确定 了 文件 模式 , 即 打 开 某 个 特 
定 的 文件 是 用 来 做 什么 的 。Fopen() 中 的 参数 及 其 用 途 如 表 11-1 所 示 。 





表 11-1 fopen() 中 的 参数 及 其 用 途 





































参数 意 说 明 
打开 文件 用 于 读 取 ， 且 从 文件 头 开 始 读 取 
r+ 读 打开 文件 用 于 读 取 和 写 入 ， 且 从 文件 头 开始 读 取 和 写 入 
:用 于 写 入 ， 且 从 文件 头 开 始 写 入 。 如 果 文 件 已 经 存在 ， 则 清空 
时 如 果 文 件 不 存在 ， 则 创建 此 文件 
目 从 文件 头 开始 写 入 。 如 果 文 件 已 经 存在 ， 
在 ， 则 创建 此 文件 
: 头 开始 写 入 。 如 果 文 件 已 经 存在 ， 则 不 会 
四 同时 fopen 返回 false， 且 PHP 生成 警告 
打开 文件 用 于 写 入 和 读 取 ， 且 从 文件 头 开 始 写 入 。 如 果 文 件 已 经 存在 ， 
和 则 不 会 被 打 寺 fopen 返回 false， 且 PHP 生成 警告 
打开 文件 仅 用 于 添加 写 入 ， 且 在 已 存在 内 容 之 后 写 入 。 如 果 文 件 不 存在 ， 
a 添加 则 创建 此 文 
i 打开 文件 用 加 写 入 和 读 取 ， 且 在 已 存在 内 容 之 后 写 入 。 如 果 文 件 不 
| 管 相 存在 ， 则 创建 此 文件 
另外 两 个 文件 模式 
b 二 进 制 (binary) 配合 以 上 的 不 同 参数 使 用 。 进 制 文人 式 不 管 是 在 Linux 或 是 Windows 
下 都 是 可 使 用 的 。 一 般 情 况 下 ， 都 选择 二 进 制 模式 
t 文本 (text) 文本 模式 只 能 在 Windows 下 被 使 用 





11.2 目录 操作 


在 PHP 中 , 利用 相关 函数 可 以 实现 对 目录 的 操作 。 常 见 目录 操作 函数 的 使 用 方法 和 技巧 如 下 。 
1. string getcwd (void ) 
该 函数 主要 用 于 获取 当前 的 工作 目录 ， 返 回 的 是 字符 串 。 下 面 举例 说 明 此 函数 的 使 用 方法 。 
【 例 11.3】 实 例文 件 : chl1\11.4.php) 
<html> 
<head> 
<title> 获取 当前 工作 目录 </title> 
</head> 
<body> 
<?php 
$dl=getcwd (); // 获 取 当 前 路 径 
echo getcwd(); // 输 出 当前 目录 








2 
</body> 
</html> 
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运行 结果 如 图 11-5 所 示 。 











攻 让 过 htpy/loc- 图 DD- CX 总 到 取 当 前 I 作 有 录 
文件 (| 入 纺 (昌吉 看 (V) 收 这 夫 (A) 工具 (帮助 (H) 























| c:vehll 








图 11-5 程序 运行 效果 
2. array scandir ( string directory, [int sorting_orden) 
返回 一 个 aray， 包含 directory 中 的 文件 和 目录 。 如 果 directory 不 是 一 个 目录 ， 则 返回 布尔 值 
FALSE, 并 产生 一 条 E_WARNING 级 别 的 错误 。 默 认 情 况 下 , 返回 值 是 按照 字母 顺序 升序 排列 的 。 
如 果 使 用 了 可 选 参数 sorting_order〔 设 为 1) ， 则 按照 字母 顺序 降序 排列 。 


下 面 举 例 说 明 此 函数 的 使 用 方法 。 

【 例 11.4】〔 实 例文 件 : chl11\11.5.php) 
<html> 
<head> 
<title> 获取 当前 工作 目录 中 的 文件 和 目录 </title> 
</head> 
<body> 

<?php 


$dir='d:/ch1l1';  ”// 定 义 指定 的 目录 
$files1l = scandir($qir); // 列 出 指定 目录 中 的 文件 和 目录 
$files2 = scandir($dir, 1); 
print_r($files1); // 输 出 指定 目录 中 的 文件 和 目录 
print r($files2); 
六 
</body> 
</html> 


运行 结果 如 图 11-6 所 示 。 











Shp/oc.. BD- BCX| SammI 放 EB. x 
文件 有 六 委 晶 。 于 看 收 闪 A】 工具 MT 孝 动 (H) 




















| Array ( [0] => . [1] => .. [2] => booked. txt ) Array ( [0] => 
booked txt [1] => .. [2] =>. ) 











图 11-6 程序 运行 效果 
3. new dir(sting directory) 
此 函数 模仿 面向 对 象 机 制 ， 将 指定 的 目录 名 转换 为 一 个 对 和 象 并 返回 。 使 用 说 明 如 下 。 





其 中 handle 属性 含义 为 目录 句柄 、path 属性 的 含义 为 打开 目录 的 路 径 、 函 数 read(void) 含 义 为 
读 取 目录 、 函 数 rewind ( void ) 含 义 为 复位 目录 、 函 数 close ( void ) 含 义 为 关闭 目录 。 

下 面 通过 实例 说 明 此 函数 的 使 用 方法 。 

【 例 11.5】〔 实 例文 件 : ch11\11.6.php) 





运行 结果 如 图 11-7 所 示 。 


Handle: Resource id #3 
Path: d:/chll 


boaked txt 





图 11-7 程序 运行 效果 
4. chdir (string directory) 


此 函数 将 PHP 的 当前 目录 改 为 directory。 如 果 成 功 则 返回 TRUE， 失 败 则 返回 FALSE。 下 面 
举例 说 明 此 函数 的 使 用 方法 。 
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【 例 11.6】《 实 例文 件 : chl1\11.7.php) 


<html> 
<head> 
<title> 将 当前 目录 修改 directory</title> 
</head> 
<body> 
<?php 

4f (chadir(™as/chi1")){ 

echo "当前 目录 更 改 为 : d: /ch11<br />"; 


}elsef{ 
echo "当前 目录 更 改 失 败 了 "; 
?> 
</body> 
</html> 


运行 结果 如 图 11-8 所 示 。 















当前 目录 更 改 为 : d: /chll | 





所 100% ~ 





图 11-8 程序 运行 效果 
5. void closedir ( resource dir_handle) 
此 函数 主要 是 关闭 由 dir_handle 指定 的 目录 流 ， 另 外 目录 流 必 须 之 前 被 opendir0 所 打开 。 
6. resource opendir( string path) 


此 函数 返回 一 个 目录 句柄 ， 其 中 path 为 要 打开 的 目录 路 径 。 如 果 path 不 是 一 个 合法 的 目录 或 
者 因为 权限 限制 或 文件 系统 错误 而 不 能 打开 目录 ， 则 返回 FALSE 并 产生 一 个 E_WARNING 级 别 
的 PHP 错误 信息 。 如 果 不 想 输出 错误 ， 可 以 在 opendir0 前 面 加 上 “@” 符 号 。 

【 例 11.7】 “实例 文件 :chll\11.8.php) 

<html> 

<head> 

<title> </title> 

</head> 

<body> 

<?php 

$dir = "d:/ch1l1/"; 

// 打开 一 个 目录 ， 然 后 读 取 目录 中 的 内 容 

if (is dir($dir)) { 

if ($dh = opendir($dir)) { 




















运行 结果 如 图 11-9 所 示 。 


filename; . ; filetype; dir filename: 
+»: filetype: dir filename: 
11. 3. Php : filetype: file filename: 
11.4.php : filetype: file filename: 
11.5.php : filetype: file 





11-9 程序 运行 效果 
其 中 is_dir() 函 数 主要 判断 给 定 文件 名 是 否 是 一 个 目录 ，readdir() 函 数 从 目录 句柄 中 读 取 条 目 ， 
closedir0 函 数 关闭 目录 句柄 。 
7. string readdir ( resource dir_handle) 


该 函数 主要 是 返回 目录 中 下 一 个 文件 的 文件 名 。 文 件 名 以 在 文件 系统 中 的 排序 返回 。 
【 例 11.8】《 实 例文 件 ，chll\11.9.php) 
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</html> 


运行 结果 如 图 11-10 所 示 。 


TS 七 ntpy/oc- @ D+ Bo x) localhost 


文件 闫 和 (E) 豆 者 (V) 收 训 夫人 A) 工具 (T) 帮助 (H) 


































Directory handle: Resource id #2 Files: 
. 12.3.php 12. 4 php 12. 5. php 








图 11-10 程序 运行 效果 


在 遍历 目录 时 ， 有 的 读者 会 经 常 写 出 下 面 错误 的 遍历 方法 。 
/* 这 是 错误 的 遍历 目录 的 方法 */ 
while ($file = readdir (Shandle)) { 
echo "$file\n"; 


11.3 ”文件 的 上 传 


在 网 络 中 用 户 可 以 上 传 自己 的 文件 。 实 现 这 种 功能 的 方法 有 很 多 ， 用 户 把 一 个 文件 上 传 到 服 
务 器 ， 需 要 在 客户 端 和 服务 器 端 建立 一 个 通道 传递 文件 的 字 节 流 , 并 在 服务 器 中 进行 上 传 操作 。 下 
面 介绍 一 种 代码 最 少 并 且 容易 理解 的 方法 。 

下 面 的 实例 主要 讲述 如 何 实现 文件 的 上 传 功能 ， 有 具体 操作 步骤 如 下 。 

【 例 11.9】 《实例 文件 ，chll\11.10.php 和 11.10.1.php) 


加 首先 创建 一 个 实现 文件 上 传 功能 的 文件 。 为 了 设置 保存 上 传 文件 的 路 径 ， 用 户 需 要 在 创 
建文 件 的 目录 下 新 建 一 个 名 称 为 file 的 文件 夹 。 然 后 新 建 11.10.1.php 文件 ， 代 码 如 下 。 


<html> 
<head> 
<title> 实 现 上 传 文件 </title> 
</head> 
<body> 
<?php 
if ($_POST[add]==" 上 传 ") { 
/ /根据 现 在 的 时 间 产 生 一 个 随机 数 
$randl=rand(0,9); 
$rand2=rand (0,9); 
$rand3=rand (0,9); 
$filename=date ("Ymdhms").$randl.$rand2.$rand3; 
if(empty($_FILES['file name'] ['name'])){ 
//$_FILES['file_name']['name'] 为 获取 客户 端 机 器 文件 的 原名 称 
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echo "文件 名 不 能 为 空 "; 

exit; 

} 
$oldfilename=$ FILES['file name']['name']; 
echo "<br /> 原文 件 名 为 : ".$oldfilename; 


$filetype=substr ($oldfilename strrpos ($0oldfilename,"."),strlen($oldfilename)-s 
trrpos ($oldfilename, ".")); 
echo "<br /> 原文 件 的 类 型 为 : " .$filetype; 


if(($filetype!=' .doc')&g& ($filetype!='.xls')g&g& ($filetype!="' .DOC')&& ($filetype!= 
"LST 
echo "<script>alert(' 文 件 类 型 或 地 址 错误 ') ;</script>"; 
echo "<script>location.href='11.3.php';</script>"; 
exit; 
1 
echo "<br /> 上 传 文件 的 大 小 为 ( 字 节 ): ".$_FILES['file name']['size']; 
//$_FILES['file_name'] ['size' ] 为 获取 客户 端 机 器 文件 的 大 小 ， 单 位 为 B 
if ($_FILES['file name']['size']>1000000) { 
echo "<script>alert(' 文 件 太 大 ， 不 能 上 传 ') ;</script>"; 
echo "<script>location.href='1]1.3.php';</script>"; 
exit; 
} 
echo "<br /> 文件 上 传 服务 器 后 的 临时 文件 名 为 
".$_FILES['file name']['tmp_ name']; 
4/ 取得 保存 文件 的 临时 文件 名 〈 含 路 径 ) 
$filename=$filename. $filetype; 
echo "<br /> 新 文件 名 为 : " .$filename; 
$savedir="file/".$filename; 
if(move uploaded file($ FILES['file name']['tmp name'],$savedir)){ 


$file name=basename ($savedir); // 取 得 保存 文件 的 文件 名 (不 含 路 径 》 
echo "<br /> 文件 上 传 成 功 ! 保存 为 : " .$savedir; 
lelsel{ 


echo "<script language=javascript>"; 

echo "alert (' 错 误 , 无 法 将 附件 写 入 服务 器 ! \n 本 次 发 布 失败 ! ') ;2"; 
echo "location.href="'11.3.php?';"; 

echo “</script>"; 


exit; 
下 
1 
> 
</body> 
</html> 
代码 分 析 如 下 : 
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(1) 需要 首先 创建 变量 ， 设 定 文件 的 上 传 类 型 、 保 存 路 径 和 程序 所 在 路 径 。 

(2) 实现 自 定义 函数 获取 文件 后 级 名 和 生成 随机 文件 名 。 在 上 传 过 程 中 ， 如 果 上 传 了 大 量 的 
文件 , 可 能 会 出 现 文件 名 称 重复 的 现象 , 所 以 本 实例 在 文件 上 传 的 过 程 中 ,首先 获取 上 传 文件 的 后 
级 名 称 并 结合 随机 产生 的 数字 ， 生 成 一 个 新 的 文件 ， 避 免 了 文件 名 称 重复 的 现象 。 

(3) 判断 获取 的 文件 类 型 是 否 符合 指定 类 型 ， 如 果 文 件 名 称 符合 ， 则 为 给 该 文件 生成 一 个 具 
有 随机 性 质 的 名 称 ， 并 使 用 move_uploaded _file 函数 完成 文件 的 上 传 ， 否 则 显示 提示 信息 。 


加 下 面 创建 一 个 获取 上 传 文件 的 页 面 。 创 建文 件 11.10.php， 代 码 如 下 。 


<htm1> 

<head> 

<title> 上 传 文件 </title> 

</head> 

<h3 align="center"> 上 传 文件 </h3> 

<form method="post" action="11.10.1.php" enctype="multipart/form-data"> 
<table border=0 cellspacing=0 cellpadding=0 align=center width="100%"> 


<tr> 
<td height="16"> 
<input name="file" type="file" value=" 浏 览 ”> 
<input type="submit" value=" 上 传 " name="B1"> 
</td> 
</tr> 
</table> 
</form> 
</body> 
</html> 


其 中 “<form method="post" action="11.10.1.php" enctype="multipart/form-data"> ”语句 中 method 
属性 表示 提交 信息 的 方式 是 post， 即 采用 数据 块 ，action 属性 表示 处 理 信息 的 页 面 为 11.10.1.php， 
enctype="multipart/form-data" 表 示 以 二 进 制 的 方式 传递 提交 的 数据 。 

运行 结果 如 图 11-11 所 示 。 单 击 【 浏 览 】 按 钮 ， 即 可 选择 需要 上 传 的 文件 ， 最 后 单 击 【上传 】 
按钮 即 可 实现 上 传 操 作 。 
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图 11-11 程序 运行 结果 





PHP 文件 与 目录 操作 第 11 党 





11.4 ”实战 演练 一 一 编写 文本 类 型 的 访客 计算 器 


下 面 通过 对 文本 文件 的 操作 ， 利 用 相关 函数 编写 一 个 简单 的 文本 类 型 的 访客 计算 器 。 
【 例 11.10】《〈 实 例文 件 : ch11\11.11.php) 


<html> 
<head> 
<title> 访 客 计数 器 </title> 
</head> 
<body> 
<?php 
if (!@$fp=fopen ("coun.txt","r")){ 
// 只 读 方 式 打开 coun.txt 文件 
echo "coun .txt 文件 创建 成 功 ! <br />"; 
} 
Q@$num=fgets($fp,12);  // 读 取 11 位 数字 
if ($num=="") $num=0; 
// 如 果 文 件 的 内 容 为 空 ， 初 始 化 为 0 
Snumt+; // 浏 览 次 数 加 一 
@fclose ($fp); // 关 闭 文件 
$fp=fopen ("coun.txt"，"w");// 只 写 方 式 打 开 coun .txt 文件 
fwrite ($fp, $num); // 写 入 加 一 后 结果 
fclose ($fp); // 关 闭 文件 
echo "您 是 第 " .$num." 位 浏览 者 !"; / /浏览 器 输出 浏览 次 数 
> 
</body> 
</html> 


程序 第 一 次 运行 的 结果 如 图 11-12 所 示 。 





Ee 
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coun. txt 文 件 刘 建 成 功 ! 
您 是 第 1 位 浏览 者 ! 




















图 11-12 程序 运行 效果 


由 结果 可 以 看 出 ， 该 程序 首先 创建 一 个 count.txt 的 文本 文件 ， 用 于 保存 浏览 次 数 。 首 先 打开 
这 个 文件 ， 然 后 初始 化 数据 为 0， 并 实现 加 1 操作 。 
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11.5 ”高 手 私房 菜 


技巧 1: 如 何 批 量 上 传 多 个 文件 ? 

本 章 讲 述 了 如 何 上 传单 个 文件 ， 那 么 如 何 上 传 多 个 文件 呢 ? 用 户 只 需要 在 表单 中 使 用 复 选 杠 
以 数组 式 提交 语法 即 可 。 

提交 的 表单 语句 如 下 。 





<form method="post" action="11.3.1.php" enctype="multipart/form-data"> 
<table border=0 cellspacing=0 cellpadding=0 align=center width="100%"> 
<input name="userfile[]" type="file" value=" 浏 览 1" > 
<input name=" userfile[]" type="file" value=" 浏 览 2" > 
<input name="f userfile[]" type="file" value=" 浏 览 3" > 
<input type="submit" value=" 上 传 " name="B1"> 
</table> 


</form> 

技巧 2: 如何 从 文件 中 读 取 一 行 ? 

在 PHP 网 站 开发 中 ,支持 从 文件 指针 中 读 取 一 行 。 使 用 string fgets(int handle, [int length]) 函 数 
即 可 实现 上 述 功能 。 其 中 int handle 是 要 读 入 数据 的 文件 流 指针 ，fopen() 函 数 返回 数值 ，int length 
设置 读 取 的 字符 个 数 ， 读 入 的 字符 个 数 为 length-1。 如 果 没 有 指定 length， 则 默认 为 1024 个 字 节 。 


11.6 经 典 习题 


(1) 制作 一 个 包含 读 取 指定 文件 的 例子 。 
(2) 制作 一 个 包含 写 入 数据 到 文件 的 例子 。 
(3) 制作 一 个 读 取 文 件 目录 的 例子 。 

(4) 制作 一 个 图 片 文件 上 传 的 例子 。 

(5) 制作 一 个 记录 访客 计算 器 的 例子 。 


第 12 章 图 形 图 像 处 理 


PHP 不 仅 可 以 输出 纯 HTML, 还 可 以 创建 及 操作 多 种 不 同 图 像 格式 的 图 像 文 件 , 包括 gif png、 
jpg、wbmp 和 xpm 等 。 更 方便 的 是 ，PHP 可 以 直接 将 图 像 流 输出 到 浏览 器 。 要 处 理 图 像 ， 需 要 在 
编译 PHP 时 加 上 图 像 函 数 的 GD 库 ， 另 外 还 可 以 使 用 第 三 方 的 图 形 库 。 本 章 将 讲述 图 形 图 像 的 处 
理 方法 和 技巧 。 


本 章 学 习 目标 
@ 掌握 在 PHP 中 加 载 GD 库 的 方法 
@ 掌握 图 像 图 像 创建 的 基本 方法 
@ 掌握 Jpgraph 库 的 使 用 方法 
@ 掌握 3D 饼 形 图 的 制作 方法 


12.1 在 PHP 中 加 载 GD 库 


PHP 中 的 图 形 图 像 处 理 功 能 ， 都 要 求 有 一 个 库 文件 的 支持 ， 这 就 是 GD2 库 。 PHP 5 自 带 此 
库 。 

如 果 在 Windows 7 系统 环境 下 ， 修 改 php.ini 中 extension=php_gd2.dll 前 面 的 “; ” 即 可 启用 ， 
如 图 12-1 所 示 。 





了 一 ES 
文件 (站 编 误 E) 柯 式 (0) 得 看 (V) 都 助 (H) 





;extension=php_bz2. dll a 
;extension=php_curl. dll 






p_fileinfo. dll 
网 


2. dll 
php_gettext. dll 
; extension=php_gmp. dll 
;extension=php_int1. dll 
;extension=php_imap. dll 
;extension=php_interbase. dll 
;extension=php_ldap. dll 
;extension=php_ming. dll 
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图 12-1 修改 php.ini 配置 文件 
下 面 了 解 一 下 PHP 中 常用 图 像 函 数 的 功能 ， 如 表 12-1 所 示 。 
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表 12-1 图 像 函数 的 功能 















































函数 功能 

gd info 取得 当前 安装 的 GD 库 的 信息 

getimagesize 取得 图 像 大 小 

取得 getimagesize、exif read_data、exif thumbnail、exif imagetype 
a8e_IYPe10_mme_IyPe | 所 返回 的 图 像 类 型 的 MIME 类 型 

image2wbmp 以 WBMP 格式 将 图 像 输 出 到 浏览 器 或 文件 
imagealphablending 设 定 图 像 的 混 色 模式 

imageantialias 是 否 使 用 antialias 功能 

imagearc 画 椭圆 弧 

imagechar 水 平地 画 一 个 字符 

imagecharup 简直 地 画 一 个 字符 

imagecolorallocate 为 一 幅 图 像 分 配 颜 色 

imagecolorallocatealpha 为 一 幅 图 像 分 配 颜 色 

imagecolorat 取得 某 像 素 的 颜色 索引 值 

imagecolorclosest 取得 与 指定 的 颜色 最 接近 的 颜色 的 索引 值 
imagecolorclosestalpha 取得 与 指定 的 颜色 最 接近 的 颜色 
imagecolorclosesthwb 取得 与 给 定 颜 色 最 接近 的 色 度 的 黑白 色 的 索引 
imagecolordeallocate 取消 图 像 颜色 的 分 配 

imagecolorexact 取得 指定 颜色 的 索引 值 

imagecolorexactalpha 取得 指定 的 颜色 的 索引 值 

imagecolormatch 使 一 个 图 像 中 调 色 板 版 本 的 颜色 与 真 彩色 版 本 更 能 匹配 
imagecolorresolve 取得 指定 颜色 的 索引 值 或 有 可 能 得 到 的 最 接近 的 替代 值 
imagecolorresolvealpha 取得 指定 颜色 的 索引 值 或 有 可 能 得 到 的 最 接近 的 替代 值 
imagecolorset 给 指定 调 色 板 索 引 设 定 颜色 

imagecolorsforindex 取得 某 索 引 的 颜色 

imagecolorstotal 取得 一 幅 图 像 的 调 色 板 中 颜色 的 数目 
imagecolortransparent 将 某 个 颜色 定义 为 透明 色 

imagecop 拷贝 图 像 的 一 部 分 

imagecopymerge 拷贝 并 合并 图 像 的 一 部 分 

imagecopymergegra 用 灰 度 拷 贝 并 合并 图 像 的 一 部 分 
imagecopyresampled 重 采 样 拷贝 部 分 图 像 并 调整 大 小 

imagecopyresized 拷贝 部 分 图 像 并 调整 大 小 

imagecreate 新 建 一 个 基于 调 色 板 的 图 像 

imagecreatefromgd2 从 GD2 文件 或 URL 新 建 一 个 图 像 
imagecreatefromgd2part 从 给 定 的 GD2 文件 或 URL 中 的 部 分 新 建 一 个 图 像 
imagecreatefromgd 从 GD 文件 或 UR 新 建 一 个 图 像 

imagecreatefromgif 从 GIF 文件 或 URL 新 建 一 个 图 像 
imagecreatefromjpeg 从 JPEG 文件 或 URL 新 建 一 个 图 像 
imagecreatefrompng 从 PNG 文件 或 URL 新 建 一 个 图 像 
imagecreatefromstring 从 字符 串 中 的 图 像 流 新 建 一 个 图 像 
imagecreatefromwbmp 从 WBMP 文件 或 URL 新 建 一 个 图 像 
imagecreatefromxbm 从 XBM 文件 或 URL 新 建 一 个 图 像 
imagecreatefromxpm 从 XPM 文件 或 URL 新 建 一 个 图 像 
imagecreatetruecolor 新 建 一 个 真 彩色 图 像 

imagedashedline 画 一 个 虚线 

imagedestroy 销毁 一 个 图 像 

imageellipse 画 一 个 椭圆 
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( 续 表 ) 
函数 功能 
Imagefill 区 域 填 充 
imagefilledarc 画 一 个 椭圆 弧 且 填充 
imagefilledellipse 画 一 个 椭圆 并 填充 
imagefilledpolygon 画 一 个 多 边 形 并 填充 
imagefilledrectangle 画 一 个 矩形 并 填充 
imagefilltoborder 区 域 填 充 到 指定 颜色 的 边界 为 止 
imagefontheight 取得 字体 高 度 
imagefontwidth 取得 字体 宽度 
imageftbbox 取得 使 用 FreeType 2 字体 的 文本 的 范围 
imagefttext 使 用 FreeType 2 字体 将 文本 写 入 图 像 
imagegd 将 GD 图 像 输 出 到 浏览 器 或 文件 
imagegif 以 GIF 格式 将 图 像 输 出 到 浏览 器 或 文件 
imagejpeg 以 _JPEG 格式 将 图 像 输出 到 浏览 器 或 文件 
imageline 画 一 条 直线 
imagepng 将 调 色 板 从 一 幅 图 像 拷贝 到 另 一 幅 
imagepolygon 画 一 个 多 边 形 
imagerectangle 画 一 个 矩形 
imagerotate 用 给 定 角度 旋转 图 像 
imagesetstyle 设 定 画 线 的 风格 
imagesetthickness 设 定 画 线 的 宽度 
imagesx 取得 图 像 宽 
imagesy 取得 图 像 高 度 
imagetruecolortopalette 将 真 彩色 图 像 转换 为 调 色 板 图 像 
imagettfbbox 取得 使 用 TmueType 字体 的 文本 的 范围 
imagettftext 用 TrueType 字体 向 图 像 写 入 文本 








12.2 图形 图 像 的 典型 应 用 案例 
下 面 讲述 图 形 图 像 的 经 典 使 用 案例 。 
12.2.1 创建 一 个 简单 的 图 像 


使 用 GD2 库 文件 ， 就 像 使 用 其 他 库 文件 一 样 。 由 于 它 是 PHP 的 内 置 库 文件 ， 不 需要 在 PHP 
文件 中 再 用 include 等 函数 进行 调用 。 以 下 实例 介绍 图 像 的 创建 方法 。 
【 例 12.1】 实例 文件 :ch12\12.1.php) 


<?php 
$im = imagecreate(200,300); / /创建 一 个 画布 
Swhite = imagecolorallocate ($im, 8,2,133); /7 设置 画布 的 背景 颜色 为 蓝 色 
imagegif ($im); // 输 出 图 像 

Ps 


运行 程序 ， 结 果 如 图 12-2 所 示 。 本 实例 使 用 imagecreate() 函 数 创建 了 一 个 宽 200 像素 、 高 300 
像素 的 画布 ， 并 设置 画布 的 RGB 值 为 《8，2，133) ， 最 后 输出 一 个 gif 格式 的 图 像 。 
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图 12-2 程序 运行 效果 


0 使 用 imagecreate(200,300) 函 数 创建 基于 普通 调 色 板 的 画布 ， 支 持 256 色 ， 其 中 200、 
300 为 图 像 的 宽度 和 高 度 ， 单 位 为 像素 。 


示 
上 面 的 实例 只 是 把 图 片 输出 到 页 面 ， 那 么 如 何 保存 和 需 
像 文 件 的 创建 方法 。 
【 例 12.2】 实例 文件 ，ch12\12.2.php) 





要 的 图 片 文件 呢 ? 下 面 通过 实例 介绍 图 


<?php 
$ysize =200; 
$xsize =300; 


$theimage = imagecreatetruecolor ($xsize, $ysize); // 创 建 图 片 画布 大 小 
$color2 = imagecolorallocate($theimage, 8,2,133); // 定 义 颜色 color2 
$color3 = imagecolorallocate($theimage, 230,22,22); // 定 义 颜色 color3 
imagefill($theimage, 0, 0,$color2); 
imagearc ($theimage, 100,100,150,200,0,270, $color3); // 创 建 一 个 弧 线 
imagejpeg ($theimage, "newimage.jpeg"); // 生 成 jpeg 格式 的 图 片 

// 输 出 png 格式 的 图 片 


header ('content-type: image/png'); 
imagepng ($theimage); 
imagedestroy ($theimage); // 清 除 对 象 ， 释 放 资 源 


人 
运行 程序 , 结果 如 图 12-3 所 示 。 同时 在 程序 文件 夹 下 生成 一 个 名 为 newimage.jpeg 的 图 片 ， 其 
内 容 与 页 面 显示 相同 。 
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图 12-3 程序 运行 效果 

【案例 分 析 】: 

(1) 其 中 ，imagecreatetruecolor() 函 数 是 用 来 创建 图 片 画 布 的 。 它 需要 两 个 参数 ， 一 个 是 x 轴 
的 大 小 ， 一 个 是 y 轴 的 大 小 。$xsize =200; 和 $ysize =300: 分 别 设 定 了 这 两 参数 的 大 小 。$theimage = 
imagecreatetruecolor($xsize,$ysize); 使 用 这 两 个 参数 生成 了 画布 ， 并 且 赋 值 为 Stheimage。 

(2) imagearc($theimage,100,100,150,200,0,270,$color3); 语 句 使 用 了 imagearc() 函 数 来 在 画布 上 
创建 一 个 弧 线 。 它 的 参数 分 为 以 下 几 个 部 分 :S$theimage 为 目标 画布 ，“100,100” 为 弧 线 中 心 点 的 
Xx、y 坐标 ，“150,200” 为 弧 线 的 宽度 和 高 度 ，“0,270” 为 顺 时 针 画 弧 线 的 起 始 度 数 和 终点 度数 ， 
在 0 到 360 度 之 间 ，$color3 为 画 弧 线 所 使 用 的 颜色 。 

(3) imagejpeg() 函 数 是 生成 jpeg 格式 的 图 片 的 函数 。imagejpeg($theimage,"newimage.jpeg"); 
把 画布 对 象 $theimage 生成 一 个 名 为 newimage.jpeg 的 jpeg 图 片 文件 , 并 且 直 接 存 储 在 当前 路 径 下 。 

(4) 同时 ，header('content-type: image/png'); 和 imagepng($theimage); 向 页 面 输出 png 格式 的 图 
其 

(5) 最 后 清除 对 象 ， 释 放 资 源 。 


12.2.2 ”使 用 GD2 函数 在 照片 上 添加 文字 


上 面 创建 了 一 个 图 片 。 如 果 想 在 图 片上 添加 文字 ， 就 需要 修改 图 片 ， 具 体 的 过 程 为 先 读 取 一 
个 图 片 ， 然 后 修改 这 个 图 片 。 
【 例 12.3】〔 实 例文 件 ，ch12\12.3.php) 


<?php 
$theimage = imagecreatefromjpeg ('newimage.jpeg'); // 读 取 图 像 并 赋值 
给 theimage 
$colorl = imagecolorallocate($theimage, 255,255,255); // 创 建 颜色 
colorl 
$color3 = imagecolorallocate($theimage, 230,22,22); // 创 建 颜色 





color3 
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imagestring($theimage, 5,60,100,'Text added to this image.'vS$Scolorl); // 向 
图 片 添加 字符 串 

// 处 理 输出 到 页 面 的 png 图 片 

header ('content-type: image/png'); 
imagepng ($theimage); 
imagepng ($theimage, 'textimage .png'); // 创 建 png 格式 图 片 
imagedestroy ($theimage); // 清 除 对 象 ， 释 放 资 源 

> 


运行 程序 ,结果 如 图 12-4 所 示 。 同时 在 程序 所 在 的 文件 夹 下 生成 一 个 名 为 newimagejpeg 的 图 
片 ， 其 内 容 与 页 面 显示 相同 。 
二 本 画 
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图 12-4 程序 运行 效果 
【案例 分 析 】: 


(1)imagecreatefromjpeg('newimage.jpeg'); 语 句 中 imagecreatefromjpeg() 函 数 从 当前 路 径 下 读 取 
newimage.jpeg 图 形 文件 ， 并 且 传 递 给 $theimage 变量 作为 对 象 ， 以 待 操作 。 

(2) 选取 颜色 后 ，imagestring($theimage,5,60,100,'Text added to this image.,$colorl); 语 句 中 的 
imagestring() 函 数 向 对 象 图 片 添加 字符 串 'Text added to this image.'。 这 里 的 参数 中 ，$theimage 为 对 
象 图 片 ，“5” 为 字体 类 型 ， 这 个 字体 类 型 的 参数 从 1 到 5 代表 不 同 的 字体 ; “60,100” 为 字符 串 
添加 的 起 始 x 与 y 的 坐标 ;'Text added to this image. 为 要 添加 的 字符 串 ， 现 在 的 情况 下 只 支持 asc 
字符 ; $colorl 为 写字 的 颜色 。 

(3) header('content-type: image/png'); 和 imagepng($theimage); 语 句 共同 处 理 输出 到 页 面 的 png 
图 片 。 之 后 imagepng($theimage,'textimage.png"); 语 句 就 创建 文件 名 为 textimage.png 的 png 图 片 ， 并 
保存 在 当前 路 径 下 。 


12.2.3 ”使 用 TrueType 字体 处 理 中 文生 成 的 图 片 
字体 处 理 在 很 大 程度 上 是 PHP 图 形 处 理 经常 要 面 对 的 问题 。imagestring() 函 数 默认 的 字体 是 十 
分 有 限 的 。 这 就 要 进入 字体 库 文件 ， 而 TureType 字体 是 字体 中 极其 常用 的 格式 。 比 如 在 Windows 


下 ， 打 开 CN\WINDOWS\Fonts 目录 ,会 出 现 很 多 字体 文件 ， 其 中 绝 大 部 分 是 TureType 字体 ， 如 图 
12-5 所 示 。 
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图 12-5 系统 中 的 字体 


PHP 使 用 GD2 库 ， 在 Windows 环境 下 ， 需 要 给 出 TureType 字体 所 在 的 文件 夹 路 径 ， 如 在 文 
件 开头 使 用 以 下 语句 : 
putenv ('GDFONTPATH=C: \WINDOWS\Fonts'); 


使 用 TureType 字体 也 可 以 直接 使 用 imagettftext0 函 数 , 它 是 使 用 ttf 字体 的 imagestring0 函 数 ， 
它 的 格式 为 : 


imagettftext (图 片 对 象 ， 字 体 大 小 ， 文 字 显示 角度 ， 起 始 x 坐标 ， 起 始 y 坐标 ， 文 字 颜色 ， 字 体 名 
称 ， 文 字 信 息 ) 


另外 一 个 很 重要 的 问题 就 是 ，GD 库 中 的 imagettftext() 函 数 默 认 无 法 支持 中 文人 字符， 添加 到 图 
片上 去 的 。 这 是 因为 GD 库 的 imagettftext() 函 数 对 于 字符 的 编码 是 采用 的 UTF-8 编码 格式 , 而 简体 
中 文 的 默认 格式 为 GB2312。 

下 面 就 介绍 这 样 的 一 个 例子 ， 具 体操 作 步 骤 如 下 。 

把 CN\WINDOWS\Fonts 下 的 字体 文件 simhei.ttf 复制 到 和 文件 12.4.php 同 目录 下 。 

加 在 网 站 目录 下 建立 12.4.php， 输 入 以 下 代码 并 保存 。 

<?php 


$ysize =200; 
$xsize =300; 


Stheimage = imagecreatetruecolor ($xsize,S$ysize); // 创 建 画布 、 填 充 颜 色 
color2 

$color2 = imagecolorallocate($theimage, 8,2,133); // 定 义 颜色 color2 

$color3 = imagecolorallocate($theimage，230,22,22);  // 定 义 颜色 color3 

imagefill($theimage, 0, 0,$color2); // 给 画布 填充 颜色 color2 

$fontname='simhei.ttf'; // 将 黑体 字 的 路 径 赋 值 给 变量 
fontname 

$zhtext = "这 是 一 个 把 中 文 用 黑体 显示 的 图 片 。"; 

$text = iconv ("GB2312", "UTF-8", $zhtext); / /中 文 编码 转换 为 UTF-8 


imagettftext ($theimage,12,0,20,100,$color3, $fontname, $text); // 将 字符 串 写 到 
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画布 上 
header ('content-type: image/png'); // 输 出 为 png 格式 
imagepng ($theimage); 
imagedestroy ($Stheimage); // 清 除 对 象 ， 释 放 资 源 
2 


运行 程序 ， 结 果 如 图 12-6 所 示 。 
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图 12-6 程序 运行 效果 








【案例 分 析 】: 


(1) 其 中 imagefill($theimage, 0, 0,$color2):; 语 句 用 于 创建 画布 、 填 充 颜色 。 

(2) $fontname='simheittf; 语 句 确认 当前 目录 下 的 黑体 字 的 tf 文件 ， 并 且 把 路 径 赋 值 给 
$fontname 变量 。 

(3) $zhtext 中 为 中 文字 符 ， 它 的 编码 为 GB2312。 为 了 转换 此 编码 为 UTF-8， 使 用 $text 
=iconv("GB2312", "UTF-8", $zhtext); 语 句 把 $zhtext 中 的 中 文 编码 转换 为 UTF-8, 并 赋值 给 $text 变量 。 

(4) imagettftext($theimage,12,0,20,100,$color3,$fontname,$text); 语 句 按 照 imagettftext() 函 数 的 
格式 分 别 确认 了 参数 。$theimage 为 目标 图 片 ,，“12” 为 字符 的 大 小 ，“0” 为 显示 的 角度 ，“20,100” 
为 字符 串 显示 的 初始 x 和 y 的 值 ，$fontname 为 已 经 设 定 的 黑体 ， $text 为 已 经 转换 为 UTF-8 格式 的 
中 文字 符 。 


12.3 Jpgraph 库 的 使 用 


Jpgraph 是 一 个 功能 强大 且 十 分 流行 的 PHP 外 部 图 片 处 理 库 文件 , 它 是 建立 在 内 部 库 文件 GD2 
库 之 上 的 。 它 的 优点 是 建立 了 很 多 方便 操作 的 对 象 和 函数 ， 能够 大 大 简化 使 用 GD 库 对 图 片 进行 处 
理 的 编程 过 程 。 


12.3.1 Jpgraph 的 安装 
Jpgraph 的 安装 就 是 PHP 对 Jpgraph 类 库 的 调用 。 可 以 采用 多 种 形式 ， 但 是 ， 首 先 都 需要 到 
Jpgraph 的 官方 网 站 下 载 类 库 文 件 的 压缩 包 ， 下 载 的 最 新 压缩 包 为 了 pgraph3.5.0bl 。 


解压 以 后 ， 如 果 是 Linux 系统 ， 可 以 把 它 放置 在 lib 目录 下 ， 并 且 使 用 下 面 的 语句 重 命名 此 类 
库 的 文件 夹 。 
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ln -s jpgraph-3.x jpgraph 


如 果 是 Windows 系统 ， 在 本 机 WAMP 环境 下 ， 则 可 以 把 类 库 文件 夹 放 在 www 目录 下 , 或 者 
放置 在 项 目的 文件 夹 下 。 然后 在 程序 中 引用 的 时 候 , 直接 使 用 require_once() 命 令 , 并 且 指 出 Jpgraph 
类 库 相对 于 此 应 用 的 路 径 。 

在 本 机 环境 下 ， 把 jpgraph 文件 夹 放置 在 DA\PHP 7\ch12 文件 夹 下 。 在 应 用 程序 的 文件 中 加 载 
此 库 ，require_once ('jpgraph/src/jpgraph.php"); 即 可 。 


12.3.2 ”Jpgraph 的 配置 


使 用 Jpgraph 类 之 前 ， 需 要 对 PHP 系统 的 一 些 限制 性 参数 进行 修改 。 具 体 修改 以 下 3 个 方面 
的 内 容 。 


@ 需要 到 php.ini 中 修改 内 存 限制 ,memory_limit 至 少 为 32MB, 本 机 环境 为 momery_limit = 
64m。 

@ 最 大 执行 时 间 max_execution time 要 增加 ，Jpgraph 类 的 官方 推荐 时 间 为 30 秒 ， 即 
max_execution time =30。 

@ 用 “;” 号 注释 掉 output_buffering 选项 。 


12.3.3 ”制作 柱 形 与 折线 统计 图 


安装 设置 生效 以 后 ， 就 可 以 使 用 此 类 库 了 。 由 于 Jpgraph 有 很 多 实例 ， 所 以 读者 可 以 轻松 地 通 
过 实例 来 学 习 。 
下 面 通过 实例 来 学 习 Jpgraph 类 的 使 用 方法 和 技巧 。 


加 找到 安装 过 的 jpgraph 类 库 文件 夹 ， 在 其 下 的 src 文件 夹 下 找到 Examples 文件 夹 。 找 到 
barlinealphaex1.php 文件 ， 将 其 复制 到 ch12 文件 夹 下 。 在 浏览 器 中 打开 ， 其 代码 如 下 。 


<?php 

// content="text/plain; charset=utf-8" 

require once ('jpgraph/jpgraph.php'); 

require once ('jpgraph/jpgraph bar.php'); 

require once ('jpgraph/jpgraph line.php'); 

$ydata = array(10,120,80,190,260,170,60,40,20,230); 
$ydata2 = array (10,70, 40,120,200,60,80,40,20,5); 
$months = $gDateLocale->GetShortMonth (); 

$graph = new Graph (300,200); 

$graph->SetScale ("textlin"); 

$graph->SetMarginColor ('white'); 
$graph->SetMargin(30,1,20,5); 

$graph->SetBox(); 

$graph->SetFrame (false); 
$graph->tabtitle->Set ('Year 2003'); 
$graph->tabtitle->SetFont (FF ARIAL,FS BOLD,10); 
$graph->ygrid->SetFil]l (true, '#DDDDDD@O0.5','#BBBBBB@O0.5°'); 
S$graph->ygrid->SetLinestyle('dashed'); 
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S$graph->ygrid->SetColor('gray'); 
S$graph->xgrid->Show(); 
S$graph->xgrid->SetLineStyle('dashed'); 
S$graph->xgrid->SetColor('gray'); 
$graph->xaxis->SetTickLabels ($months); 
$graph->xaxis->SetFont (FF_ARIAL, FS NORMAL, 8); 
S$graph->xaxis->SetLabelAngle (45); 
$bplot = new BarPlot ($ydata); 
$bplot->SetWwigdth(0.6); 
$fcol="'#440000°'; 

$tcol="#FF9090"; 


$bplot->SetFillGradient ($fcol, $tcol,GRAD LEFT REFLECTION); 


$bplot->SetWeight (0); 

$graph->Add ($bplot); 

$lplot = new LinePlot ($ydata2); 
$lplot->SetFillColor ('skyblue@0.5'); 
$1lplot->SetColor('navy@0.7'); 
$1lplot->SetBarCenter (); 
$1plot->mark->SetType (MARK SQUARE); 
$lplot->mark->SetColor ('blue@0.5'); 
$1lplot->mark->SetFillColor('lightblue'); 
$lplot->mark->SetSize(6); 
$graph->Add ($lplot); 

S$graph->Stroke () 7 

?> 


四 修改 require_once (jpgraphVjpgraph.php); 为 require_once (jpgraph/src/ijpgraph.php);。 修 改 


require_once (‘jpgraph/jpgraph bar.php ); 为 require_once (jpgraph/src/jpgraph_bar.php"); 。 


修改 


require_once ("jpgraph/jpgraph_line.php'); 为 require_once (jpgraph/src/jpgraph_line.php);， 以 载 入 本 机 


jpgraph 类 库 。 
加 运行 barlinealphaexl.php， 结 果 如 图 12-7 所 示 。 
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图 12-7 程序 运行 效果 
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【案例 分 析 】 : 


(1) 其 中 require once (jpgraph/src/jpgraph.php);:、require_once (jpgraph/src/jpgraph_bar.php)); 
和 require_once (jpgraph/src/jpgraph_line.php"); 语 句 加 载 了 jpgraph 基本 类 库 jpgraph.php、 柱 状 图 类 
库 jpgraph_bar.php 和 折线 图 类 库 /jpgraph_line.php。 

(2)$ydata= array(10,120,80,190,260,170,60,40,20,230); 和 $ydata2 = array(10,70,40,120,200,60,80, 
40,20,5); 语 句 定义 了 柱状 图 和 折线 图 在 y 轴 上 的 数据 坐标 ， 这 也 是 图 形 要 表示 的 主要 信息 。 

(3) $months = $gDateLocale->GetShortMonth(): 定 义 了 月 份 使 用 短 名 表示 。 

(4) $graph = new Graph(300,200): 语 句 创 建 图 形 $graph， 高 300 像素 ， 宽 200 像素 。 

(5)$graph->SetScale("textlin"); 语 句 确认 刻度 为 自动 生成 的 刻度 形式 。$graph-> SetMarginColor 
("white'); 语 句 确认 图 形 边框 颜色 为 白色 。 

(6) $graph->SetMargin(30,1,20,5); 语 句 调 整 边框 宽度 。$graph->SetBox(); 语 句 在 背景 图 上 添加 
边框 。$graph->SetFrame(false); 语 句 取消 整个 图 片 的 边框 。 

(7)$graph->tabtitle->Set('Year 2003'); 语 句 添 加 图 片 标题 。 S$graph->tabtitle->SetFont(FF_ARIAL, 
FS_BOLD,10); 语 句 设 定 标题 样式 。 

(8) $graph->ygrid->SetFill(true,#DDDDDD@0.5''#BBBBBB@0.5"); 语 句 设 定 y 轴 方向 上 的 网 
格 填充 颜色 和 亮度 。$graph->ygrid->SetLineStyle('dashed); 语句 设 定 y 轴 方 向 上 的 网 格 线 的 样式 为 
虚线 。$graph->ygrid->SetColor('gray); 语句 设 定 y 轴 方向 上 的 网 格 线 的 颜色 。$graph->xgrid->Show(); 
语句 、$graph->xgrid->SetLineStyle('dashed'); 语 句 和 $graph->xgrid-> SetColor('gray"); 语 句 是 对 x 轴 方 
向 网 格 的 同 理 设 定 。 

(9) $graph->xaxis->SetTickLabels($months); 语 名 为 对 x 轴 的 设 定 ， 它 使 用 的 是 先前 定义 的 
$months 变量 中 的 数据 。$graph->xaxis->SetFont(FF_ ARIAL,FS NORMAL.8); 语 句 设 定 样式 。 
$graph->xaxis->SetLabelAngle(45); 语 句 设 定 角度 。 

(10) $bplot = new BarPlot($ydata); 语 句 采用 先前 的 $ydata 数据 生成 柱状 图 。$bplot ->SetWidth 
(0.6); 定 义 宽度 。$bplot->SetFillGradient ($fcol,$tcol,GRAD_LEFT_REFLECTION); 填充 柱状 图 ， 并 
且 使 用 填充 的 渐变 样式 和 两 个 渐变 的 颜色 。$graph->Add($bplot):; 语 句 添加 柱状 图 到 图 形 中 。 

(11) $lplot = new LinePlot($ydata2); 语 句 用 $ydata2 数组 生成 折线 图 。$lplot->SetFillColor 
('skyblue(@0.5'); 和 $lplot->SetColor('navy(@0.7"); 语 句 定义 折线 区 域 的 颜色 和 透明 度 。 

(12) $lplot>mark->SetType(MARK SQUARE): 定 义 折 线 图 标记 点 的 类 型 。$lplot->mark-> 
SetColor('blue(@0.5"); 定 义 颜色 和 透明 度 。S$lplot->mark->SetSize(6):; 定 义 大 小 。$graph->Add($lplot); 
语句 添加 折线 图 到 图 形 中 。 

(13) $graph->Stroke(); 语 句 表示 把 此 图 传递 到 浏览 器 显示 。 


12.3.4 制作 圆 形 统计 图 
下 面 就 通过 圆 形 统计 图 实例 的 介绍 来 了 解 jpgraph 类 的 使 用 ， 具 体 步骤 如 下 。 


找到 安装 过 的 jpgraph 类 库 文件 夹 ， 在 其 下 的 src 文件 夹 下 找到 Examples 文件 夹 。 找 到 
balloonex1.php 文件 ， 将 其 复制 到 ch12 文件 夹 下 ， 其 代码 如 下 。 

<?php 

require once ('jpgraph/jpgraph.php'); 
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require once ('jpgraph/jpgraph scatter.php'); 
$datax = array(1,2,3,4,5,6,7,8); 
$datay = array(12,23,95,18,65,28,86,44); 
function FCallback ($aVval) { 
// This callback will adjust the fill color and size of 
// the datapoint according to the data value according to 
if( $aVval < 30 ) $c = "blue"; 
elseif( $aVal < 70 ) $c = "green"; 
else $c="red"; 
return array (floor ($aVal/3),"",$c); 
} 
$graph = new Graph (400,300,'auto'); 
$graph->SetScale ("linlin"); 
$graph->img->SetMargin (40,100, 40,40); 
$graph->SetShadow(); 
$graph->title->Set ("Example of ballon scatter plot"); 
$graph->yaxis->scale->SetGrace (50,10); 
$graph->xaxis->SetPos('min'); 
$spl = new ScatterPlot ($datay, $datax); 
$spl->mark->SetType (MARK_ FILLEDCIRCLE); 
$spl->value->Show(); 
$spl->value->SetFont (FF_FONT]1, FS_ BOLD); 
$spl->mark->SetCallback ("FCallback"); 
$spl->SetLegend ('Year 2002'); 
$graph->Add ($sp1); 
$graph->stroke (); 
了 六 


贺 修改 require_once (jpgraph/jpgraph.php'): 为 require_once (jpgraph/src/jpgraph.php):。 修 改 
require_once ('jpgraph/jpgraph_scatter.php'); 为 require_once (jpgraph/src/jpgraph_scatter.php);。 以 载 入 
本 机 jpgraph 类 库 。 

贺 运行 balloonex1.php， 结 果 如 图 12-8 所 示 。 
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图 12-8 ”balloonex1.php 页 面 效果 
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【案例 分 析 】: 


(1) 其 中 ，require_once (jpgraph/src/jpgraph.php): 语 句 和 require_once (jpgraph/src/jpgraph_ 
scatter.php'); 语 句 加 载 了 jpgraph 基本 类 库 jpgraph.php 和 圆 形 图 类 库 jpgraph_bar.php。 

(2) $datax 和 $datay 定义 了 两 组 要 表现 的 数据 。 

(3) function FCallback($aVal){} 函 数 定义 了 不 同 数值 范围 内 的 图 形 的 颜色 。 

(4) $graph = new Graph(400,300,'auto'); 语 句 生成 图 形 。$graph->SetScale("linlin"); 生 成 刻度 。 
$graph->img->SetMargin(40,100,40,40); 设 置 图 形 边 杠 。 Sgraph->SetShadow(); 设 置 阴影 。 
$graph->title->Set("Example of ballon scatter plot"); 设 置 标 题 。$graph->xaxis->SetPos('min'); 设 置 x 轴 
为 的 位 置 为 初始 值 。 

(5) $spl = new ScatterPlot($datay,$datax); 生 成 数据 表示 图 。 $spl->mark->SetType 
(MARK_FILLEDCIRCLE); 设 置 数 据 表示 图 的 类 型 。$sp1l->value->Show(); 展 示 数 据 表示 图 。 
$sp1->value->SetFont(FF_FONTI1,FS_BOLD); 设 定 展示 图 的 字体 。 $sp1->SetLegend('Year 2002"): 设 置 
标题 。 

(6) $graph->Add($sp1); 语 句 添加 数据 展示 图 到 整体 图 形 中 。 

(7) $graph->Stroke(); 语 句 表示 把 此 图 传递 到 浏览 器 显示 。 


12.4 ”实战 演练 一 一 制作 3D 饼 形 统 计 图 


下 面 就 通过 3D 饼 形 图 实例 的 介绍 ， 来 了 解 Jpgraph 类 的 使 用 方法 和 技巧 ， 具 体 步骤 如 下 。 


找到 安装 过 的 jpgraph 类 库 文件 夹 ， 在 其 下 的 src 文件 夹 下 找到 Examples 文件 夹 。 找 到 
pie3dex3.php 文件 ， 将 其 复制 到 ch12 文件 夹 下 ， 打 开 代 码 如 下 。 


<?php 

require once ('jpgraph/ jpgraph.php'); 

require once ('jpgraph/jpgraph pie.php'); 

require once ('jpgraph/jpgraph pie3d.php'); 

$data = array (20,27,45,75,90); 

$graph = new PieGraph (450,200); 

$graph->Set Shadow (); 

$graph->title->Set ("Example 1 3D Pie plot"); 

S$graph->title->SetFont (FF_VERDANA, FS _ BOLD,18); 

$graph->title->SetColor ("darkblue"); 

$graph->legend->Pos (0.5,0.8); 

$pl = new PiePlot3d($data); 

$pl->SetTheme ("sand"); 

SP1->SetCenter (0.4); 

$pl->SetAngle (30); 

$pl->value->SetFont (FF_ARIAL,FS NORMAL,12); 

$pl->SetLegends (array ("Jan", "Feb", "Mar","Apr", "May", "Jun", "Jul", "Aug", "Sep" 
OCS YN 

$graph->Add ($p1); 
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S$graph->Stroke(); 
> 


四 修改 require_once ('jpgraph/jpgraph.php"); 为 require_once ("jpgraph/src/jpgraph.php");。 修 改 
require_once (jpgraph/jpgraph_pie.php"); 为 require once ('jpgraph/src/ jpgraph pie.php ');。 修 改 
require_once (jpgraph/jpgraph_pie3d.php'); 为 require_once ('jpgraph/src/ jpgraph_pie3d.php ");。 以 载 入 
本 机 jpgraph 类 库 。 

贺 运行 pie3dex3.php， 结 果 如 图 12-9 所 示 。 
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图 12-9 pie3dex3.php 页 面 效果 


【案例 分 析 】: 


(1) 其 中 require_once (jpgraph/src/jpgraph.php'); 语 句 、require_once (jpgraph/jpgraph_pie.php"); 
语句 和 require_once (jpgraph/jpgraph_pie3d.php'); 语 句 加 载 了 jpgraph 基本 类 库 jpgraph.php、 饼 形 图 
类 库 jpgraph_ pie.php 和 3d 饼 形 图 类 库 jpgraph_ pie3d.php。 

(2) $data 定义 了 要 表现 的 数据 。 

(3) $graph = new PieGraph(450,200); 生 成 图 形 。$graph->SetShadow(); 设 定 阴 影 。 

(4) $graph->title->Set("Example 1 3D Pie plot"); 设 定 标题 。$graph->title->SetFont (FF_VERDANA,， 
FS_BOLD,18); 设 定 字 体 和 字体 大 小 。 S$graph->title->SetColor("darkblue"); 设 定 颜 色 。 
S$graph->legend->Pos(0.5,0.8); 设 定 图 例 在 整个 图 形 中 的 位 置 。 

(5) $pl = new PiePlot3d($data); 生 成 饼 形 图 。$pl->SetTheme("sand"); 设 置 饼 形 图 模板 。 
$p1->SetCenter(0.4); 设 置 饼 形 图 的 中 心 。$p1->SetAngle(30); 设 置 饼 形 图 角度 。S$p1->value->SetFont 
(FF_ARIAL,FS_NORMAL,12): 设 置 字体 。S$p1->SetLegends(array("Jan",.….,"Oct")); 设 置 图 例文 字 信 
息 。 

(6) Sgraph->Add($p1); 向 整个 图 形 添加 饼 形 图 。$graph->Stroke(); 把 此 图 传递 到 浏览 器 显示 。 
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12.5 ”高 手 私房 菜 


技巧 1: 不同 格式 的 图 片 在 使 用 上 有 何 区 别 ? 


答 : JPEG 格式 是 一 个 标准 。JPEG 格式 经 常用 来 存储 照片 和 拥有 很 多 颜色 的 图 片 。 它 不 强调 
压缩 ， 强 调 的 是 对 图 片 信息 的 保存 。 如 果 使 用 图 形 编辑 软件 缩小 jpeg 格式 的 图 片 ， 那 么 它 原本 所 
包含 的 一 部 分 数据 就 会 丢失 。 并且 这 种 数据 的 丢失 , 通过 肉眼 是 可 以 察觉 到 的 。 这 种 格式 不 适合 包 
含 简单 图 形 颜色 或 文字 的 图 片 。 

PNG 格式 是 指 Portable Network Graghics， 这 种 图 片 格式 是 用 来 取代 g 计 格式 的 。 同 样 ， 图 片 
使 用 png 格式 的 大 小 要 小 于 使 用 gif 格 式 的 大 小 。 这 种 格式 是 一 种 低 损失 压缩 的 网 络 文件 格式 。 这 
种 格式 的 图 片 适合 于 包含 文字 、 直 线 或 色 块 的 信息 。PNG 支持 透明 、 伽 马 校正 等 。 但 是 png 不 像 
gif 一样 支持 动画 功能 ， 并 且 IE 6 不 支持 png 的 透明 功能 。 低 损 压 缩 意味 着 压缩 比 不 高 ， 所 以 它 不 
适合 用 于 照片 这 类 的 图 片 ， 否 则 文件 将 太 大 。 

GIF 是 指 Graphics Interchange Format， 它 也 是 一 种 低 损 压 缩 的 格式 ， 适 合用 于 包含 文字 、 直 线 
或 色 块 的 信息 的 图 片 。 它 使 用 的 是 24 位 RGB 色彩 中 的 256 色 。 由 于 色彩 有 限 所 以 也 不 适合 用 于 
照片 一 类 的 大 图 片 。 对 于 其 适合 的 图 片 ， 它 具有 不 丧失 图 片 质量 却 能 大 幅 压缩 的 图 片 大 小 的 优势 。 
另外 ， 它 支持 动画 。 


技巧 2: 如 何 选 择 自己 想 要 的 RGB 颜色 呢 ? 


可 以 使 用 Photoshop 里 面 的 颜色 选取 工具 获取 想 要 的 颜色 。 如 果 使 用 的 是 Linux 系统 ， 可 以 使 
用 开源 的 工具 GIMP 中 的 颜色 选取 工具 。 


12.6 ”经典 习题 


(1) 制作 一 个 包含 读 取 指定 文件 的 例子 。 
(2) 制作 一 个 包含 写 入 数据 到 文件 的 例子 。 
(3) 制作 一 个 读 取 文件 目录 的 例子 。 

(4) 制作 一 个 图 片 文 件 上 传 的 例子 。 

(5) 制作 一 个 记录 访客 计算 器 的 例子 。 


第 13 章 Cookie 和 会 话 管 理 


由 于 HTTP Web 协议 是 无 状态 协议 ， 对 于 事务 处 理 没 有 记忆 能 力 。 缺 少 状态 意味 着 如 果 后 续 
处 理 需 要 前 面 的 信息 ， 则 它 必须 重 传 ， 这 样 可 能 导致 每 次 连接 传送 的 数据 量 增 大 。 客 户 端 与 服务 器 
进行 动态 交互 的 Web 应 用 程序 出 现 之 后 ，HTTP 无 状态 的 特性 严重 阻碍 了 这 些 应 用 程序 的 实现 ， 
毕竟 交互 是 需要 承前启后 的 ， 简 单 的 购物 车 程序 也 要 知道 用 户 到 底 在 之 前 选择 了 什么 商品 。 于 是 ， 
两 种 用 于 保持 HTTP 连接 状态 的 技术 就 应 运 而 生 了 ， 一 个 是 Cookie， 而 另 一 个 则 是 SESSION。 其 
中 Cookie 将 数据 存储 在 客户 端 ， 并 显示 永久 的 数据 存储 。Session 将 数据 存储 在 服务 器 端 ， 保 证 数 
据 在 程序 的 单 次 访问 中 持续 有 效 。 本 章 主要 讲述 Cookie 和 Session 的 使 用 方法 和 应 用 技巧 。 
本 章 学 习 目 标 

@ 掌握 Cookie 的 基本 操作 方法 
熟悉 Session 的 基本 概念 
熟悉 Cookie 和 Session 的 区 别 和 联系 
掌握 会 话 管理 的 基本 操作 


13.1 ”Cookie 基本 操作 
下 面 介绍 Cookie 的 含义 和 基本 用 法 。 
13.1.1 什么 是 Cookie 


Cookie 常用 于 识别 用 户 。Cookie 是 服务 器 留 在 用 户 计 算 机 中 的 小 文件 。 每 当 相 同 的 计算 机 通 
过 浏览 器 请 求 页 面 时 ， 它 同时 会 发 送 Cookie。 

Cookie 的 工作 原理 是 ， 当 一 个 客户 端 浏览 器 连接 到 一 个 URL， 它 会 首先 扫描 本 地 存储 的 
Cookie， 如 果 发 现 其 中 有 和 此 URL 相关 联 的 Cookie， 将 会 把 它们 返回 给 服务 器 端 。 

Cookie 通常 应 用 于 以 下 几 个 方面 。 


(1) 在 页 面 之 间 传 递 变量 。 因 为 浏览 器 不 会 保存 当前 页 面 上 的 任何 变量 信息 ， 如 果 页 面 被 关 
闭 ， 则 页 面 上 的 所 有 变量 信息 也 会 消失 。 通 过 Cookie， 可 以 把 变量 值 在 Cookie 中 保存 下 来 ， 然 后 
另外 的 页 面 可 以 重新 读 取 这 个 值 。 
(2) 记录 访客 的 一 些 信息 。 利 用 Cookie 可 以 记录 客户 曾经 输入 的 信息 或 者 记录 访问 网 页 的 次 数 。 
(3) 通过 把 所 查看 的 页 面 保存 在 Cookie 临时 文件 夹 中 ， 可 以 提高 以 后 的 浏览 速度 。 
用 户 可 以 通过 header 以 如 下 格式 在 客户 端 生成 Cookie: 





Set-cookie:NAME = VALUE; [expires=DATE;] [path=PATH;] [domain=DOMAIN NAME;] 


[secure] 


NAME 为 cookie 的 名 称 ，VALUE 为 cookie 的 值 ，expires=DATE 为 到 期 日 ，path=PATH; 
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domain=DOMAIN_NAME; 为 与 某 个 地 址 相对 应 的 路 径 和 域名 ，secure 表示 cookie 不 能 通过 单一 的 
HTTP 连接 传递 。 


13.1.2 ”创建 Cookie 


通过 PHP， 用 户 能 够 创建 Cookie。 创 建 Cookie 使 用 setcookie() 函 数 ， 它 的 语法 格式 如 下 : 
setcookie (名 称 ，cookie 值 ， 到 期 日 ， 路 径 ， 域 名 ，secure) 
其 中 的 参数 与 Set-cookie 中 的 参数 意义 相同 。 


0 setcookie() 函 数 必 须 位 于 <html> 标 签 之 前 。 


提 示 


在 - 


在 下 面 的 例子 中 ,将 创建 名 为 user 的 cookie, 为 它 赋 值 为 ”Cookie 保存 的 值 * 并 且 规定 此 cookie 


-小 时 后 过 期 。 


【 例 13.1】“〈 实 例文 件 ，ch13\13.1.php) 


<?php 

setcookie ("user"，" Cookie 保存 的 值 "，time () +3600); 
> 

<html> 

<body> 

</body> 

</html> 


运行 上 述 程序 ,会 在 Cookies 文 件 夹 下 自动 生成 一 个 Cookie 文件 ,有 效 期 为 一 个 小 时 , 在 Cookie 


失效 后 ，Cookies 文件 自动 被 删除 。 


0! 如 果 用 户 没有 设置 Cookie 的 到 期 时 间 ， 则 在 关闭 浏览 器 时 会 自动 删除 Cookie 数据 。 
提 示 
13.1.3” 读 取 Cookie 


那么 如 何 取 回 Cookie 的 值 呢 ? 在 PHP 中 ， 使 用 $_COOKIE 变量 取 回 Cookie 的 值 。 下 面 通过 


实例 讲解 如 何 取 回 上 面 创建 的 名 为 user 的 Cookie 的 值 ， 并 把 它 显 示 在 页 面 上 。 


【 例 13.2】 《实例 文件 :chl3\13.2.php) 


<?php 

// 输出 一 个 cookie 

echo $ COOKIE["user"]; 
// 显示 所 有 的 cookie 
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print r($ COOKIFE); 


?> 


程序 运行 效果 如 图 13-1 所 示 。 
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Cookie 保存 的 值 Array ( [user] => Cookie 保存 的 值 ) 








图 13-1 程序 运行 效果 


用 户 可 以 通过 isset() 函 数 来 确认 是 否 已 设置 cookie。 下 面 通过 实例 来 讲解 。 
【 例 13.3】 《实例 文件 :ch13\13.3.php) 


<html> 
<body> 
<?php 
if (isset($ COOKIE["user"])) // 如 果 Cookie 文件 存在 
echo "Welcome " . $ COOKIE["user"] . "!<br />"; 
else // 如 果 cookie 文件 不 存在 
echo "Welcome guest!<br />"; 
</body> 
</html> 


程序 运行 效果 如 图 13-2 所 示 。 
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图 13-2 程序 运行 效果 
13.1.4 删除 Cookie 
常见 的 删除 Cookie 的 方法 有 两 种 ， 包 括 在 浏览 器 中 手动 删除 和 使 用 函数 删除 。 


1. 在 浏览 器 中 手动 删除 
由 于 Cookie 自动 生成 的 文本 会 存在 于 正 浏览 器 的 Cookies 临时 文件 夹 中 ， 在 浏览 器 中 删除 
Cookie 文件 是 比较 快捷 的 方法 。 具 体 的 操作 步骤 如 下 。 
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在 浏览 器 页 面 中 选择 【工具 】〗 选 项 ， 在 弹出 的 下 拉 菜单 中 选择 【Internet 选项 】 菜 单 命令 ， 
如 图 13-3 所 示 。 
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图 13-3 选择 【Internet 选 项】 菜单 命令 


打开 【Internet 选项 〗】 对 话 框 ， 在 【常规 〗】 选 项 卡 中 单 击 【 删 除 〗】 按 钮 ， 如 图 13-4 所 示 。 
打开 【删除 浏览 的 历史 记录 了】 对话 框 ， 选 中 【Cookie】 复 选 框 ， 单 击 【删除 〗】 按 钮 即 可 ， 
如 图 13-5 所 示 。 返回 到 【Internet 选项 】 对 话 框 ， 单 击 【 确 定 】 按 钮 即 可 完成 删除 Cookie 的 操作 。 
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图 13-4 【Internet 选项 】 对 话 框 图 13-5 【删除 浏览 的 历史 记录 】 对 话 框 
2. 使 用 函数 删除 


删除 Cookie 仍然 使 用 setcookie0) 函 数 。 当 删除 Cookie 时 ， 将 第 二 个 参数 设置 为 袍 ， 第 三 个 参 
数 的 过 期 时 间 设 置 为 小 于 系统 的 当前 时 间 即 可 。 
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【 例 13.4】“〔 实 例文 件 ，ch13\13.4.php) 


<?php 
// 将 cookie 的 过 期 时 间 设 置 为 比 当前 时 间 减 少 10 秒 
setcookie ("user", "", time()-10); 


?> 


在 上 面 的 代码 中 ，time() 函 数 返 回 的 是 当前 的 系统 时 间 ， 把 过 期 时 间 减 少 10 秒 ， 这 样 过 期 时 
间 就 会 变 成 过 去 的 时 间 ， 从 而 删除 Cookie。 如 果 将 过 期 时 间 设 置 为 0， 也 可 以 直接 删除 Cookie。 


13.2 认识 Session 
下 面 介绍 Session 的 一 些 基 本 概念 和 使 用 方法 。 


13.2.1 什么 是 Session 


由 于 HTTP 是 无 状态 协议 ， 也 即 是 说 HTTP 的 工作 过 程 是 请 求 与 回应 的 简单 过 程 ， 所 以 HTTP 没 
有 一 个 内 置 的 方法 来 存储 这 个 过 程 中 各 方 的 状态 。 比 如 ， 当 同一 个 用 户 向 服务 器 发 出 两 个 不 同 的 请 求 
时 ， 虽 然 服务 器 端 都 会 给 以 相应 的 回应 ， 但 是 它 并 没有 办 法 知道 这 两 个 动作 是 由 同一 个 用 户 发 出 的 。 

由 此 ,会话 (Session) 管理 应 运 而 生 。 通 过 使 用 一 个 会 话 ， 程 序 可 以 跟踪 用 户 的 身份 和 行为 ， 
并 且 根 据 这 些 状 态 数据 ， 给 用 户 以 相应 的 回应 。 


13.2.2 Session 的 基本 功能 


在 PHP 中 , 每 一 个 Session 都 有 一 个 ID。 这 个 Session ID 是 一 个 由 PHP 随机 生成 的 加 密 数字 。 
这 个 Session ID 通过 cookie 存储 在 客户 端 浏 览 器 中 ， 或 者 直接 通过 URL 传递 到 客户 端 ， 如 果 在 某 
个 URL 后 面 看 到 一 长 串 加 密 的 数字 ， 这 很 有 可 能 就 是 Session ID 了 。 

Session ID 就 像 一 把 钥匙 用 来 注册 到 session 变量 中 。 而 这 些 session 变量 是 存储 在 服务 器 端的 。 
Session ID 是 客户 端 唯 一 存在 的 会 话 数据 。 

使 用 Session ID 打开 服务 器 端 相对 应 的 session 变量 ， 跟 用 户 相 关 的 会 话 数 据 便 一 目 了 然 。 默 
认 情 况 下 ， 在 服务 器 端的 session 变量 数据 是 以 文件 的 形式 加 以 存储 的 ， 但 是 会 话 变量 数据 也 经 常 
通过 数据 库 进 行 保存 。 


13.2.3 ”Cookie 与 Session 


在 浏览 器 中 ， 有 些 用 户 出 于 安全 性 的 考虑 ， 关 闭 了 其 浏览 器 的 Cookie 功能 。Cookie 将 不 能 正 
常 工 作 。 

使 用 Session 可 以 不 需要 手动 设置 Cookie，PHP Session 可 以 自动 处 理 。 可 以 使 用 会 话 管理 ， 
及 PHP 中 的 session_get_cookie_params() 函 数 来 访问 Cookie 的 内 容 。 这 个 函数 将 返回 一 个 数组 ， 包 
括 Cookie 的 生存 周期 、 路 径 、 域 名 、secure 等 。 它 的 格式 为 : 














session get_cookie params (生存 周期 、 路 径 、 域 名 、secure) 
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13.2.4 在 Cookie 或 URL 中 存储 Session ID 


PHP 默认 情况 下 会 使 用 Cookie 来 存储 sessio ID。 但 是 如 果 客 户 端 浏览 器 不 能 正常 工作 ， 就 需 
要 用 URL 方式 传递 session ID。 如 果 在 php.ini 中 的 session.use_trans_sid 设置 为 启用 的 状态 ， 就 可 
以 自动 通过 URL 来 传递 session ID。 

不 过 通过 URL 传递 session ID 会 产生 一 些 安全 问题 。 如 果 这 个 连接 被 其 他 用 户 复制 并 使 用 ， 
有 可 能 造成 用 户 判断 的 错误 。 其 他 用 户 可 能 使 用 session ID 访问 目标 用 户 的 数据 。 

或 者 可 以 通过 程序 把 session ID 存储 到 常量 SID 中 ， 然 后 通过 一 个 连接 传递 。 


13.3 会话 管理 


一 个 完整 的 会 话 包括 创建 会 话 、 注 册 会 话 变量 、 使 用 会 话 变量 和 删除 会 话 变量 。 下 面 介绍 有 
关 会 话 管理 的 基本 操作 。 


13.3.1 创建 会 话 


session_register() 函 数 创建 。 

1. PHP 自动 创建 

用 户 可 以 在 php.ini 中 设 定 session.auto_start 为 启用 。 但 是 使 用 这 种 方法 的 同时 ， 不 能 把 
session 变量 对 象 化 。 应 定义 此 对 象 的 类 ， 必 须 在 创建 会 话 之 前 加 载 ， 然 后 新 创建 的 会 话 才能 加 
载 此 对 象 。 

2. 使 用 session_start() 函 数 

这 个 函数 首先 检查 当前 是 否 已 经 存在 一 个 会 话 ， 如 果 不 存在 ， 它 将 创建 一 个 全 新 的 会 话 ， 并 
且 这 个 会 话 可 以 访问 超 全 局 变量 $_ SESSION 数组 。 如 果 已 经 有 一 个 存在 的 会 话 ， 函 数 会 直接 使 用 
这 个 会 话 ， 加 载 已 经 注册 过 的 会 话 变量 ， 然 后 使 用 。 

session_start() 函 数 的 语法 格式 如 下 : 


bool session start (void); 


session_start() 浮 数 必 须 位 于 <html> 标 签 之 前 。 
提 示 
【 例 13.5】〔 实 例文 件 :， ch13\13.5.php) 


<?php 
session start(); 
> 
<html> 
<body> 
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</body> 
</html> 


上 面 的 代码 会 向 服务 器 注册 用 户 的 会 话 ， 以 便 可 以 开始 保存 用 户 信息 ， 同 时 会 为 用 户 会 话 分 
配 一 个 UID。 


3. 使 用 session_register() 函 数 

在 使 用 session_register() 函 数 之 前 ,需要 在 php.ini 文件 中 将 register_globals 设置 为 on, 然后 需 
要 重启 服务 器 。session_register() 函 数 通过 为 会 话 登 录 一 个 变量 来 隐 含 地 启动 会 话 。 
13.3.2 ”注册 会 话 变 量 

会 话 变 量 被 启动 后 ,全 部 保存 在 数组 $_SESSION 中 。 用 户 可 以 通过 对 $_SESSION 数组 赋值 来 
注册 会 话 变 量 。 

例如 ， 启 动 会 话 ， 创 建 一 个 Session 变量 并 赋予 xiaoli 的 值 ， 代 码 如 下 : 


<?php 
session start(); // 启 动 Session 
$_SESSION['name']='xiaoli'; // 声 明 一 个 名 为 name 的 变量 ， 并 赋值 xiaoli 
?> 


这 个 会 话 变量 值 会 在 此 会 话 结束 或 被 注销 后 失效 。 或 者 还 会 根据 php.ini 中 的 
Session.gc_maxlifetime (当前 系统 设置 的 1440 秒 ， 也 就 是 24 小 时 ) 设置 会 话 最 大 生命 周期 数 ， 过 
期 而 失效 。 

13.3.3 ”使 用 会 话 变量 


使 用 会 话 变量 ， 首 先 要 判断 会 话 变量 是 否 存在 一 个 会 话 ID， 如 果 不 存在 ， 则 需要 创建 一 个 ， 
并 且 能 够 通过 $_ SESSION 变量 进行 访问 。 如 果 已 经 存在 ， 则 将 这 个 已 经 注册 的 会 话 变量 载 入 以 供 
用 户 使 用 。 

在 访问 $_SESSION 数组 时 ， 先 要 使 用 isset() 或 empty() 来 确定 $_ SESSION 中 会 话 变量 是 否 
为 空 。 

例如 下 面 的 代码 所 示 : 


<?php 
IE (! empty ($_SESSION['session name']) ) ; // 判 断 会 话 变量 是 否 为 空 
$ssvalue=$_SESSION['session name']; // 声 明 一 个 名 为 name 的 变量 ， 并 赋 
值 xiaoli 
2 


下 面 通 过 实例 讲解 存储 和 取 回 $_SESSION 变量 的 方法 。 
【 例 13.6】〔 实 例文 件 ，ch13\13.6.php) 


<?php 








程序 运行 效果 如 图 13-6 所 示 。 





13-6 ”程序 运行 效果 


13.3.4 ”注销 和 销毁 会 话 变量 


注销 会 话 变量 使 用 unset() 函 数 即 可 ， 如 unset ($_SESSION[mame]) 。 (不 再 需要 使 用 php4 
中 的 session_unrgister() 或 session_unset()) 。unset() 函 数 用 于 释放 指定 的 session 变量 ， 代 码 如 下 : 


如 果 要 注销 所 有 会 话 变量 ， 只 需要 向 $_SESSION 赋值 一 个 空 数组 就 可 以 了 ， 如 $_SESSION = 
array()。 注 销 完 成 后 ， 使 用 session_destory0) 销 毁 会 话 即 可 ， 其 实 就 是 清除 相应 的 sessionID。 代 码 


如 下 : 
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13.4 ”实战 演练 一 一 会 话 管理 的 综合 应 用 
下 面 通过 一 个 综合 案例 ， 讲 述 会 话 管理 的 综合 应 用 。 


在 网 站 根 目录 下 建立 一 个 文件 夹 ， 名 为 session。 
贺 在 session 文件 夹 下 建立 opensession.php， 输 入 以 下 代码 并 保存 。 


<?php 

session start (); 

$_SESSION['name'] = "王小明 "; 

echo "会 话 变 量 为 :" .$_SESSION[ 'name']; 
2 


<a href='usesession.php'> 下 一 页 </a> 
加 在 session 文件 夹 下 建立 usesession.php， 输 入 以 下 代码 并 保存 。 


<?php 
session start (); 
echo "会 话 变 量 为 :".$_SESSION['name']."<br />"; 
echo $_SESSION['name'] .", 你 好 。"; 

?> 


<a href='closesession.php'> 下 一 页 </a> 
四 在 session 文件 夹 下 建立 closesession.php， 输 入 以 下 代码 并 保存 。 


<?php 
session start (); 
unset($_SESSION['name']); 
if (isset($ SESSION['name'])){ 
echo "会 话 变 量 为 :".$_SESSION['name']; 
}else{ 
echo "会 话 变 量 已 注销 。"; 
| 
session_destroy ()， 
> 


贺 运行 opensession.php 文件 ， 结 果 如 图 13-7 所 示 。 
3 | 





x | 全 localhost 


文件 和 总 (E) 查看 人 V) 收 大 夫 (A) 工具 (T) 大 细 (H) 
会 话 变量 为 :王小明 下 一 页 








图 13-7 程序 运行 结果 
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国 单 击 页 面 中 的 “下 一 页 ”链接 ， 运 行 结果 如 图 13-8 所 示 。 


[< 同 htp/loc. @ P- BCx| locahost 


文件 (有 ] ” 编 罚 (E) 查看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 

















| 会 话 变量 为 :王小明 
| 王小明 , 你 好 。 下 一 页 














图 13-8 ”程序 运行 结果 
单 击 页 面 中 的 “下 一 页 ”链接 ， 运 行 结果 如 图 13-9 所 示 。 


【¢ 回 Bhtpiloc.. @ PD- Box|g lochost 


文件 (有 ” 妨 辑 (E) 。 坦 看 (V) 收藏 夫 (A) 工具 (T) 帮助 (H) 


























会 话 变量 已 注销 - 








图 13-9 程序 运行 结果 


13.5 ”高 手 私房 菜 


技巧 1: 如果 浏 览 器 不 支持 Cookie， 怎 么 办 ? 

如 果 应 用 程序 涉及 不 支持 Cookie 的 浏览 器 ， 不 得 不 采取 其 他 方法 在 应 用 程序 中 从 一 张 页 面向 
另 一 张 页 面 传递 信息 。 一 种 方式 是 从 表单 传递 数据 。 

下 面 的 表单 在 用 户 单 击 提交 按钮 时 向 welcome.php 提交 了 用 户 输入 : 


<html> 

<body> 

<form action="welcome.php" method="post"> 
Name: <input type="text" name="name" /> 
Age: <input type="text" name="age" /> 
<input type="submit" /> 

</form> 

</body> 

</html> 


要 取 回 welcome.php 中 的 值 ， 可 以 设置 如 下 代码 : 


<html> 





<body> 
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Welcome <?php echo $_POST ["name"]; ?>.<br /> 
You are <?php echo $ POST["age"]; ?> years old. 
</body> 

</html> 


技巧 2: Cookie 的 生命 周期 是 多 久 ? 

如 果 Cookie 不 设 定 失 效 时 间 ， 则 表示 它 的 生命 周期 为 未 关闭 浏览 器 前 的 时 间 段 ， 一 旦 浏览 器 
关闭 ，Cookie 则 会 自动 消失 。 

如 果 设 定 了 过 期 时 间 ， 那 么 浏览 器 会 把 Cookie 保存 到 硬盘 中 ， 在 超过 有 效 期 前 ， 用 户 打开 下 
浏览 器 会 依然 有 效 。 

由 于 浏览 器 最 多 存储 300 个 Cookie 文件 , 每 个 Cookie 文件 最 大 支持 4KB, 所 以 一 旦 超过 容量 
的 限制 ， 则 浏览 器 会 自动 随机 地 删除 Cookies。 


13.6 ”经典 习题 


(1) 制作 一 个 创建 、 读 取 和 删除 Cookie 的 例子 。 

(2) 在 浏览 器 中 手动 删除 Cookie。 

(3) 制作 一 个 通过 session_start0 函 数 创建 会 话 的 例子 。 
(4) 制作 一 包含 注销 和 销毁 会 话 变量 的 例子 

(5) 制作 一 个 综合 管理 会 话 的 例子 。 


第 14 章 MySQL 数据 库 基础 


MySQL 是 一 个 小 型 关系 数据 库 管 理 系 统 ， 与 其 他 大 型 数据 库 管 理 系统 如 Oracle、DB2、SQL 
Server 等 相 比 ，MySQL 规模 小 、 功 能 有 限 ， 但 是 它 体积 小 、 速 度 快 、 成 本 低 ， 且 它 提 供 的 功能 对 
稍微 复杂 的 应 用 来 说 已 经 够 用 ， 这 些 特 性 使 得 MySQL 成 为 世界 上 最 受 欢 迎 的 开放 源 代码 数据 库 。 
MySQL 支持 在 多 种 平台 下 工作 。 在 Windows 平台 下 可 以 使 用 二 进 制 的 安装 软件 包 或 免 安 装 版 的 软 
件 包 进行 安 装 ， 二进制 的 安装 包 提供 了 图 形 化 的 安装 向 导 过 程 ， 免 安装 版 直接 解压 缩 即 可 使 用 。 本 
书 以 目前 最 新 的 版 本 MySQL 5.7 为 例 进行 讲解 ， 主 要 讲述 MySQL 服务 器 的 一 些 常见 操作 。 

本 章 学 习 目 标 

@ 热 悉 什么 是 MySQL 

@ 掌握 启动 和 登录 MySQL 的 方法 

@ MySQL 常用 图 形 管理 工具 


14.1 什么 是 MySQL 
本 节 将 介绍 MySQL 的 基本 知识 。 


14.1.1 客户 机 -服务 器 软件 


主 从 式 架构 〈Client-Server Model) 或 客户 端 /服务 器 〈ClienVyServer) 结构 简称 C/S 结构 ， 是 一 
种 网 络 架 构 ， 通 常 在 该 网 络 架 构 下 软件 分 为 客户 端 〈Client) 和 服务 器 (Server) 。 

服务 器 是 整个 应 用 系统 资源 的 存储 与 管理 中 心 ， 多 个 客户 端 则 各 自 处 理 相应 的 功能 ， 共 同 实 
现 完整 的 应 用 。 在 客户 端 /服务 器 结构 中 ， 客 户 端 用 户 的 请 求 被 传送 到 数据 库 服务 器 ， 数 据 库 服务 
器 进行 处 理 后 ， 将 结果 返回 给 用 户 ， 从 而 减少 了 网 络 数据 传输 量 。 

用 户 使 用 应 用 程序 时 ， 首 先 启动 客户 端 通过 有 关 命 令 告知 服务 器 进行 连接 以 完成 各 种 操作 ， 
而 服务 器 则 按照 此 请 示 提 供 相 应 的 服务 。 每 一 个 客户 端 软件 的 实例 都 可 以 向 一 个 服务 器 或 应 用 程序 
服务 器 发 出 请 求 。 

这 种 系统 的 特点 就 是 ， 客 户 端 和 服务 器 程序 不 在 同一 台 计 算 机 上 运行 ， 这 些 客户 端 和 服务 器 
程序 通常 归属 于 不 同 的 计算 机 。 

主 从 式 架 构 通过 不 同 的 途径 应 用 于 很 多 不 同类 型 的 应 用 程序 ， 比 如 ， 现 在 人 们 最 熟悉 的 在 因特网 
上 使 用 的 网 页 ， 当 顾客 想 要 在 当当 网 站 上 买书 的 时 候 ， 电 脑 和 网 页 浏览 器 就 被 当 作 一 个 客户 端 ， 同 时 ， 
组 成 当当 网 的 电脑 、 数 据 库 和 应 用 程序 就 被 当 作 服务 器 。 当 顾客 的 网 页 浏览 器 向 当当 网 请 求 搜寻 数据 
库 相 关 的 图 书 时 ， 当 当 网 服务 器 从 当当 网 的 数据 库 中 找 出 所 有 该 类 型 的 图 书信 息 ， 结 合成 一 个 网 页 ， 
再 发 送 回顾 客 的 浏览 器 。 服 务 器 端 一 般 使 用 高 性 能 的 计算 机 ， 并 配合 使 用 不 同类 型 的 数据 库 ， 比 如 
Oracle、Sybase 或 者 是 MySQL 等 ;客户 端 需要 安装 专门 的 软件 ， 比 如 浏览 器 。 
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14.1.2 ”MySQL 版 本 
针对 不 同 用 户 ，MySQL 分 为 两 个 不 同 的 版 本 。 
@ MySQL Community Server (社区 版 ) 该 版 本 完全 免费 ， 但 是 官方 不 提供 技术 支持 。 
@ 。 MySQL Enterprise Server (企业 版 ): 它 能 够 以 很 高 的 性 价 比 为 企业 提供 数据 仓库 应 用 ， 
支持 ACID 事物 处 理 ， 提 供 完整 的 提交 、 回 滚 、 崩 演 恢 复 和 行 级 锁定 功能 。 但 是 该 版 本 
需 付费 使 用 ， 官 方 提供 电话 技术 支持 。 


C7 MySQL Cluster 主要 用 于 架设 集群 服务 器 ， 需 要 在 社区 版 或 企业 版 基础 上 使 用 。 
提 示 
MySQL 的 命名 机 制 由 3 个 数字 和 1 个 后 级 组 成 ， 例 如 mysql-5.7.10。 


@ 第 1 个 数字 (5) 是 主 版 本 号 ， 描 述 了 文件 格式 ， 所 有 版 本 5 的 发 行 版 都 有 相同 的 文件 格 
ER 

@ 第 2 个 数字 (7) 是 发 行 级 别 ， 主 版 本 号 和 发 行 级 别 组 合 在 一 起 便 构 成 了 发 行 序列 号 。 

@ 第 3 个 数字 (10) 是 在 此 发 行 系列 的 版 本 号 ， 随 每 次 新 分 发 版 本 递增 。 通 常 选择 已 经 发 
行 的 最 新 版 本 。 

在 MySQL 开发 过 程 中 ， 同 时 存在 多 个 发 布 系列 ， 每 个 发 布 处 在 成 熟 度 的 不 同 阶段 。 

@ MySQL 5.7 是 最 新 开发 的 稳定 (GA ) 发 布 系列 ， 是 将 执行 新 功能 的 系列 ， 目 前 已 经 可 以 
正常 使 用 。 

@。 MySQL 5.6 是 比较 稳定 (GA ) 发 布 系列 。 只 针对 漏洞 修复 重新 发 布 ， 没 有 增加 会 影响 稳 
定性 的 新 功能 。 

@ MySQL 5.1 是 前 一 稳定 ( 产品 质量 ) 发 布 系列 。 只 针对 严重 漏洞 修复 和 安全 修复 重新 发 
布 ， 没 有 增加 会 影响 该 系列 的 重要 功能 。 


对 于 MySQL 4.1、4.0 和 3.23 等 低 于 5.0 的 老 版 本 ， 官 方 将 不 再 提供 支持 。 而 所 有 发 

布 的 MySQL ( Current Generally Available Release ) 版 本 已 经 经 过 严格 标准 的 测试 ， 可 

提 示 。 以 保证 其 安全 可 靠 性 。 针 对 不 同 的 操作 系统 ， 读 者 可 以 在 MySQL 官方 下 载 页 面 
( http://dev.mysql.com/downloads/ ) 下 载 相 应 的 安装 文件 。 


14.1.3 ”MySQL 的 优势 

MySQL 的 主要 优势 如 下 。 

@ ”速度 : 运行 速度 快 。 
价格 : MySQL 对 多 数 个 人 用 户 来 说 是 免费 的 。 
容易 使 用 : 与 其 他 大 型 数据 库 的 设置 和 管理 相 比 ， 其 复杂 程度 较 低 ， 易 于 学 习 。 
可 移植 性 : 能 够 工作 在 众多 不 同 的 系统 平台 上 ， 例 如 Windows、Linux、Unix、Mac OS 等 。 
丰富 的 接口 : 提供 了 用 于 C、C++、Eiffel、Java、Perl、PHP、Python、Ruby 和 Tcl 等 语 
言 的 API。 
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@ ”支持 查询 语言 MySQL 可 以 利用 标准 SQL 语法 和 支持 ODBC (开放 式 数据 库 连 接 ) 的 
应 用 程序 。 

@ 安全 性 和 连接 性 : 十 分 灵活 、 安 全 的 权限 和 密码 系统 ， 允 许 基于 主机 的 验证 。 连 接 到 服 
务 器 时 ， 所 有 的 密码 传输 均 采 用 加 密 形 式 ， 从 而 保证 了 密码 的 安全 。 由 于 MySQL 是 网 络 
化 的 ， 因 此 可 以 在 因特网 上 的 任何 地 方 访问 ， 提 高 数据 共享 的 效率 。 


14.2 ”启动 服务 并 登录 MySQL 数据 库 


用 户 可 以 下 载 MySQL 并 安装 ， 安 装 完 毕 之 后 ， 需 要 启动 服务 器 进程 ， 否 则 客户 端 无 法 连接 数 
据 库 ， 客 户 端 通过 命令 行 工具 登录 数据 库 。 本 节 将 介绍 如 何 启动 MySQL 服务 器 和 登录 MySQL 的 
方法 。 


14.2.1 启动 MySQL 服务 


在 前 面 的 配置 过 程 中 , 已 经 将 MySQL 安装 为 Windows 服务 , 当 Windows 启动 .停止 时 , MySQL 
也 自动 启动 、 停 止 。 不 过 ， 用 户 还 可 以 使 用 图 形 服务 工具 来 控制 MySQL 服务 器 或 从 命令 行使 用 
NET 命令 。 

可 以 通过 Windows 的 服务 管理 器 查看 ， 具 体 的 操作 步骤 如 下 。 


单 击 【开始 】〗 菜 单 ， 在 弹出 的 菜单 中 选择 【和 运行】 命令 ， 打 开 【 和 运行 】 对 话 框 ， 如 图 14-1 
所 示 。 

贺 在 【打开 】 文本 框 中 输入 services.msc， 单 击 【 确 定 〗 按 钮 ， 打 开 Windows 的 【服务 管理 
器 】〗， 在 其 中 可 以 看 到 服务 名 为 MySQL 的 服务 项 ， 其 右边 的 状态 为 “已 启动 ”， 表 明 该 服务 已 经 
启动 ， 如 图 14-2 所 示 。 


搞 述 。 状态 。 启动 类 型 。 登录 为 

Windows 次 要 二 公所 给 入 的 全 称 ， 为 后 打开 生 应 的 程序 人 MySQL 已 局 动 9 网 洛 服务 
SH NetMsmq Liste.. Rece.. 网 络 服 务 
A OO % Netpipe Listene Rece.. i 本 地 服务 
党 NetTcp Listener... Rece.. 自动 本 地 服务 
名 NetTcp Port Sh.. Prov... 手动 本 地 服务 
祝 Nedogon 为 用 -. 手动 本 地 系统 
ED EE 入 Network Access 网络. 手动 


高 Network Connec… 管理 .已 启动 手动 本 地 系统 


图 ”使 用 管理 权限 创建 此 任务 .， 








图 14-1 【运行 】 对 话 框 图 14-2 服务 管理 器 窗口 


由 于 设置 了 MySQL 为 自动 启动 ， 在 这 里 可 以 看 到 ， 服 务 已 经 启动 ， 而 且 启动 类 型 为 自动 。 如 
果 没 有 “已 启动 ”字样 ， 说 明 MySQL 服务 未 启动 。 启 动 方法 为 : 单 击 【 开 始 】 菜 单 ， 选 择 【 运 行 】 
命令 ， 在 【运行 】 对 话 框 中 输入 cmd， 回 车 后 弹出 Windows 7 命令 提示 符 界面 。 然 后 输入 “net start 
mysql”， 按 回 车 键 ， 就 能 启动 MySQL 服务 了 ,停止 MySQL 服务 的 命令 为 “net stop mysql”， 如 
图 14-3 所 示 。 


C7 输入 的 MySQL 是 服务 的 名 字 。 如 果 读者 的 MySQL 服务 的 名 字 是 DB 或 其 他 名 字 ， 应 
< 该 输入 “net start DB” 或 其 他 名 称 。 
不 


ws 
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也 可 以 直接 双击 MySQL 服务 , 打开 MySQL 属性 对 话 框 ， 在 其 中 通过 单 击 【启动 】 或 【停止 】 
按钮 来 更 改 服务 状态 ， 如 图 14-4 所 示 。 











MysQL 的 履 性 [二 地 计算 名 画 
常规 “| 登录 | 浆 复 。 | 依存 关系 
服务 名 称 ， MySQL 
显示 名 称 : myS9L 
画 管理 吴 : C\Windows\system32\cmd.exe 二 








已 启动 
便 上 GD 暂停 中 
当 从 此 处 启动 服务 时 ， 您 可 指定 所 适用 的 启动 参数 。 





确定 取消 














图 14-3 ”在 命令 行 中 启动 和 停止 MySQL 图 14-4 MySQL 服务 属性 对 话 柜 
14.2.2 登录 MySQL 数据 库 
当 MySQL 服务 启动 完成 后 , 便 可 以 通过 客户 端 来 登录 MySQL 数据 库 了 。 在 Windows 操作 系 
统 下 ， 可 以 通过 两 种 方式 登录 MySQL 数据 库 。 
1. 以 Windows 命令 行 方 式 登录 
具体 的 操作 步骤 如 下 。 
加 单 击 【开始 〗 按 钮 ， 在 弹出 的 菜单 中 选择 【运行 】 菜 单 命令 ， 打 开 【 和 运行 〗 对 话 框 ， 在 
其 中 输入 命令 cmd， 如 图 14-5 所 示 。 
贺 单 击 【确定 】 按 钮 ， 打 开 DOS 窗口 ， 输 入 以 下 命令 并 按 Enter 键 确认 ， 如 图 14-6 所 示 。 
cd C:\Program Files\MySQL\MySQL Server 5.7\bin\ 
了 运行 Ea 


Windows 将 根据 您 所 输入 的 名 称 ， 为 您 打开 框 应 的 程序 . 
文件 夹 、 文 档 或 Internet 资源 . 





夯 管 理 员 : CAWindows\system32\cmd exe 





打开 (O): 国 加 ~ 


留 使 用 管理 权限 创建 此 任务 。 











确定 | 取消 浏览 (B)… 
图 14-5 【运行 】 对 话 框 图 14-6 DOS 窗口 


好 在 DOS 窗口 中 可 以 通过 登录 命令 连接 到 MySQL 数据 库 ， 和 连接 MySQL 的 命令 格式 为 : 


mysql -h hostname -u username -p 














其 中 MySQL 为 登录 命令 ，-h 后 面 的 参数 是 服务 器 的 主机 地 址 ， 在 这 里 客户 端 和 服务 器 位 于 
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户 名 称 ， 在 这 














同一 台 机 器 上 ， 所 以 输入 localhost 或 者 IP 地 址 127.0.0.1，-u 后 面 跟 登 录 数 据 库 的 
里 为 root，-p 后 面 是 用 户 登录 密码 。 
接 下 来 ， 输 入 如 下 命令 : 
-h localhost -u root -p 
会 提示 输入 密码 (Enter password) ， 这 里 输入 在 前 面 配置 向 导 中 自己 


mysql 
按 回 车 键 ， 系 设置 的 
密码 ， 验 证 正确 后 ， 即 可 登录 到 MySQL 数据 库 ， 如 图 14-7 所 示 。 











L Community Server 《GPL 


Dracle and/or its affiliates. All rights reserved. 


Sorporation an 


input stat 








图 14-7 Windows 命令 行 登录 窗口 


当 窗 口中 出 现 如 图 14-7 所 示 的 说 明 信 息 ， 且 命令 提示 符 变 为 “MySQL>” 时 ,表明 已 


经 成 功 登 录 MySQL 服务 器 ， 可 以 开始 对 数据 库 进 行 操作 。 


旨 


提 


2. 使 用 MySQL Command Line Client 登录 
依次 选择 【开始 】 代 所 有 程序 】 【MySQL] 人 MySQL Server 5.7】|【 MySQL 5.7 Command Line 


Client】 菜 单 命令 ， 进 入 密码 输入 窗口 ， 如 图 14-8 所 示 。 





ja | 


本 MySQL 57 Command Line Client - Unicode 








图 14-8 ”密码 输入 窗口 


输入 正确 的 密码 之 后 ， 就 可 以 登录 到 MySQL 数据库 了 。 
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14.2.3 配置 Path 变量 


在 前 面 登 录 MySQL 服务 器 的 时 候 ， 不 能 直接 输入 MySQL 登录 命令 ， 因 为 没有 把 MySQL 的 
bin 目录 添加 到 系统 的 环境 变量 里 面 ， 所 以 不 能 直接 使 用 MySQL 命令 。 如 果 每 次 登录 都 输入 “cd 


C:\Program Files\MySQL\MYyYSQL Server 5.7\bin”， 才 能 使 用 MySQL 等 其 他 命令 工具 ， 这 样 比较 麻 
烦 。 


下 面 介绍 如 何 手动 配置 PATH 变量 。 具 体 的 操作 步骤 如 下 。 


在 桌面 上 右 击 【我 的 电脑 】〗 图标 ， 在 弹出 的 快捷 菜单 中 选择 【属性 】 了 菜单 命令 ， 如 图 14-9 
所 示 


加 在 打开 的 【系统 】 窗 口中 ， 单 击 【 高 级 系统 设置 】 选 项 ， 如 图 14-10 所 示 。 














OO [es, su , mem ,sn E73 
HI 二 本 日 ”至 在 V) 工具 (1) 孝 _(H) 
i 坦 看 有 关 计算 机 的 基本 信息 
网 See Windows 版 本 
网 82 Windcws 7 ER 
Say 县 了 所 有 后 200 Microsoft Corporation。 集 加 所 有 仅 科 ， 
9 上 
Ee 
si 1 
Nae nacwr7 归 机 
3 各 国 wn ene 
EE ts AMD Aionignl 11 Xa 245 proceceor 
PO 290 GHz 
Windows Update RAM): 400 G8 (3.25 GB 可 用 ) 
住 肯 党 主 和 0 工 琶 Re RN 
属性 (R) [从 和 2 本 所 于 此 呈 二 各 和 第 攻 角 窒 流入 








图 14-9 【我 的 电脑 】 属 性 菜单 图 14-10 【系统 】 窗 口 


加 打开 【系统 属性 】 对 话 框 ， 并 选择 【高 级 】〗 选 项 卡 ， 如 图 14-11 所 示 。 


加 单 击 【 环 境 变量 】〗 按 钮 ， 打 开 【 环 境 变量 〗 对 话 框 ， 在 【系统 变量 〗】 列 表 中 选择 Path 变 
量 ， 如 图 14-12 所 示 。 





庆 机 名 [本 伯 | 高梁 | 条 纺 保 折 | 运程] 








haninistrater 的 用 户 变 重 0) 
要 进行 大 多 教 更 改 ， 您 必须 作为 管理 员 登 录 。 









































性 能 雪 旺 什 
视觉 站 果 ， 处 理 器 计划 ， 内 存 使 用 ， 以 及 虚拟 内 存 Ta WUSERFROFTLEX\AppDat a\Local\Tenp 
TP KUSERPROFILEX\AppData\Local\Temp 
与 登录 有 关 的 直面 设 轩 (Bw...] Lo ] 
EET 系统 变 里 6) 
启 直 和 让 障 收复 丈量 什 
系统 启动 、 系统 失败 和 i 下 信息 05 np 加 
设置 (I)， 了 ATHEXT COW ; . EXE; BAT: CID: VBs; VBE; 
PhnrgsanR hg PR 
EF TRIE TEL 
CE ] 应 用 CC 本 
图 14-11 【系统 属性 】 对 话 框 图 14-12 【环境 变量 】 对 话 框 
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加 单 二 编辑 耽 钮 ,在 [编辑 系统 变量 了 对 话 框 中 ,将 MySQL 应 用 程序 的 bin 目录 ( C:\Program 
Files\MySQINMySQL Server 5.7\bin ) 添加 到 变量 值 中 ， 用 分 号 将 其 与 其 他 路 径 分 隔 开 ， 如 图 14-13 
所 示 。 


Path 





“am Files\MySQL\MySQL Server 5.7\bir 





图 14-13 【编辑 系统 变量 】 对 话 框 


四 添加 完成 之 后 ， 单 击 【 确 定 】 按 钮 ， 这 样 就 完成 了 配置 PATH 变量 的 操作 ， 然 后 就 可 以 
直接 输入 MySQL 命令 来 登录 数据 库 了 。 


14.3 MySQL 常用 图 形 管理 工具 


MySQL 图 形 化 管理 工具 极 大 地 方便 了 数据 库 的 操作 与 管理 ， 常 用 的 图 形 化 管理 工具 有 : 
MySQL Workbench、 phpMyAdmin、 Navicat、 MySQLDumper、 SQLyog、 MySQL ODBC Connector。 
其 中 phpMyAdmin 和 Navicat 提供 中 文 操作 界面 ，MySQL Workbench、MySQL ODBC Connector、 
MySQLDumper 为 英文 界面 。 下 面 介绍 几 个 常用 的 图 形 管理 工具 。 


1. MySQL Workbench 

MySQL 官方 提供 的 图 形 化 管理 工具 MySQ1 Workbench 完全 支持 MySQL 5.0 以 上 的 版 本 ， 在 
5.0 版 本 中 ， 有 些 功 能 将 不 能 使 用 ， 而 在 4.X 以 下 的 版 本 中 ，MySQL Workbench 分 为 社区 版 和 商业 
版 ， 社 区 版 完全 免费 ， 而 商业 版 则 是 按 年 收费 。 

下 载 地 址 :http://dev.MySQL.com/downloads/workbench/。 

2. phpMyAdmin 

phpMyAdmin 使 用 PHP 编写 ， 必 须 安装 在 Web 服务 器 中 ， 通 过 Web 方式 控制 和 操作 MySQL 
数据 库 。 通 过 phpMyAdmin 可 以 完全 对 数据 库 进 行 操作 ， 例 如 建立 、 复 制 、 删 除数 据 等 等 。 管 理 
数据 库 非常 方便 ， 并 支持 中 文 ， 不 足 之 处 在 于 对 大 数据 库 的 备份 和 恢复 不 方便 。 

下 载 地 址 : http:/www.phpmyadmin.net/。 

3. MySQLDumper 

MySQLDumper 使 用 基于 PHP 开发 的 MySQL 数据 库 备份 恢复 程序 ， 解 决 了 使 用 PHP 进行 大 
数据 库 备份 和 恢复 的 问题 。 数 百 兆 的 数据 库 都 可 以 方便 地 备份 恢复 , 不 用 担心 网 速 太 慢 而 导致 中 断 
的 问题 ， 非 常 方便 易 用 。 

下 载 地 址 : http:/www.MySQLdumperde/en/。 
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14.4 ”高 手 私房 菜 
计算 机 技术 具有 很 强 的 操作 性 ，MySQL 的 安装 和 配置 是 一 件 非常 简单 的 事 ， 但 是 在 操作 过 程 
中 也 可 能 出 现 问题 ， 读 者 需要 多 实践 、 多 总 结 。 
疑问 1; 无 法 打开 MySQL 5.7 软件 安装 包 ， 提 示 对 话 框 如 图 14-14 所 示 ， 如 何 解决 ? 


SQL Installer - Commu [se 








This application requires NET Framework 4.0. Please 
2 nstal the NET Framework then run this nstaler again 
For more nformation., please see 
httpJlgo.microsoft comfwink/?Linkd=181012 





Et 
图 14-14 无 法 安装 提示 对 话 框 

在 安装 MySQL 5.7 软 件 安装 包 之 前 ,用 户 需 要 确保 系统 中 已 经 安装 了 .Net Framework 3.5 和 .Net 
Framework 4.0， 如 果 缺 少 这 两 个 软件 ， 将 不 能 正常 地 安装 MySQL 5.7 软件 。 另 外 还 要 确保 的 
WindowsInstaller 正常 安装 。 

疑问 2: MySQL 安装 失败 ? 

安装 过 程 失败 ， 多 数 是 由 于 重新 安装 MySQL 的 缘故 ， 因 为 MySQL 在 删除 的 时 候 ， 不 能 自动 
删除 相关 的 信息 。 解 决 方法 是 ， 把 以 前 安装 的 目录 删除 掉 。 删 除 在 C 盘 的 program file 文件 夹 里 面 
MySQL 的 安装 目录 文件 夹 ;， 同 时 删除 MySQL 的 DATA 目录 ， 该 目录 一 般 为 隐藏 文件 ， 其 位 置 一 
般 在 “C:\Documents and Settings\All Users\Application Data\ MySQL ”目录 下 ,删除 掉 后 重新 安装 即 
可 。 





14.5 经典 习题 


(1) 下 载 并 安装 MySQL。 

(2) 使 用 配置 向 导 配置 MySQL 为 系统 服务 ， 在 系统 服务 对 话 框 中 ， 手 动 启动 或 者 关闭 
MySQL 服务 。 

(3) 使 用 net 命令 启动 或 者 关闭 MySQL 服务 。 

(4) 使 用 免 安 装 的 软件 包 安 装 MySQL。 


第 15 章 数据 库 的 基本 操作 


MySQL 安装 好 以 后 ， 首 先 需 要 创建 数据 库 ， 这 是 使 用 MySQL 各 种 功能 的 前 提 。 本 章 将 详细 
介绍 数据 的 基本 操作 ， 主 要 内 容 包括 : 创建 数据 库 、 删 除数 据 库 等 。 
本 章 学 习 目标 

@ 掌握 如 何 创 建 数据 库 

@ 熟悉 数据 库 的 删除 操作 

@ 掌握 综合 案例 中 数据 库 的 创建 和 删除 方法 


15.1 创建 数据 库 
MySQL 安装 完成 之 后 ， 将 会 在 其 data 目录 下 自动 创建 几 个 必需 的 数据 库 ， 可 以 使 用 SHOW 
DATABASES; 语 句 来 查看 当前 所 有 存在 的 数据 库 ， 输 入 语句 如 下 。 


mysql> SHOW DATABASES; 


information schema | 
mysql | 
Performance_schema | 
sakila 1 


6 rows in set (0.04 sec) 

可 以 看 到 ， 数 据 库 列表 中 包含 了 6 个 数据 库 ， 其 中 MySQL 是 必需 的 ， 它 描述 用 户 访问 权限 ， 
用 户 经 常 利用 test 数据 库 做 测试 的 工作 ， 其 他 数据 库 在 这 里 不 做 介绍 。 

创建 数据 库 是 在 系统 磁盘 上 划分 一 块 区 域 用 于 数据 的 存储 和 管理 ， 如 果 管 理 员 在 设置 权限 的 
时 候 为 用 户 创建 了 数据 库 ， 则 可 以 直接 使 用 ， 和 否则 ， 需 要 自己 创建 数据 库 。MySQL 中 创建 数据 库 
的 基本 SQL 语法 格式 为 : 


CREATE DATABASE database name; 
“database_name” 为 要 创建 的 数据 库 的 名 称 ， 该 名 称 不 能 与 已 经 存在 的 数据 库 重 名 。 
【 例 15.1】 创建 测试 数据 库 test_db， 输 入 语句 如 下 。 


CREATE DATABASE test db; 
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数据 库 创建 好 之 后 ， 可 以 使 用 SHOW CREATE DATABASE 声明 查看 数据 库 的 定义 。 
【 例 15.2】 查 看 创建 好 的 数据 库 test_db 的 定义 ， 输 入 语句 如 下 。 


mysql> SHOW CREATE DATABASE test db\G 
玉 商 大 。 OW 太太 
Database: test db 
Create Database: CREATE DATABASE ‘test db /*!40100 DEFAULT CHARACTER SET utf8 */ 
1 row in set (0.00 sec) 


可 以 看 到 ， 如 果 数 据 库 创建 成 功 ， 将 显示 数据 库 的 创建 信息 。 
再 次 使 用 SHOW DATABASES; 语 句 来 查看 当前 所 有 存在 的 数据 库 ， 输 入 语句 如 下 。 


mysql> SHOW databases; 


information schema | 
mysql | 
performance_schema | 
sakila 1 
test 1 
test_db 1 
world 1 


~ 


rows in set (0.05 sec) 


可 以 看 到 ， 数 据 库 列 表 中 包含 了 刚刚 创建 的 数据 库 test_db 和 其 他 已 经 存在 的 数据 库 的 名 称 。 


15.2 ”删除 数据 库 
删除 数据 库 是 将 已 经 存在 的 数据 库 从 磁盘 空间 上 清除 ， 清 除 之 后 ， 数 据 库 中 的 所 有 数据 也 将 
一 同 被 删除 。 删除 数据 库 语句 和 创建 数据 库 的 命令 相似 MySQL 中 删除 数据 库 的 基本 语法 格式 为 : 
DROP DATABASE database name; 
“database_name” 为 要 删除 的 数据 库 的 名 称 ， 如 果 指定 的 数据 库 不 存在 ， 则 删除 出 错 。 
【 例 15.3】 删 除 测试 数据 库 test_db， 输 入 语句 如 下 。 
DROP DATABASE test db; 


语句 执行 完毕 之 后 ， 数 据 库 test_db 将 被 删除 ， 再 次 使 用 SHOW CREATE DATABASE 声明 查 
看 数据 库 的 定义 ， 结 果 如 下 。 

mysql> SHOW CREATE DATABASE test db\G 

ERROR 1049 (42000) : Unknown database 'test db' 

ERROR: 

No query specified 
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执行 结果 给 出 一 条 错误 信息 : “ERROR 1049 (42000): Unknown database ‘test_db'”， 即 数据 








库 test_db 已 不 存在 ， 删 除 成 功 。 


使 用 DROP DATABASE 命令 时 要 非常 谨慎 ， 在 执行 该 命令 时 ，MySQL 不 会 给 出 任何 
提醒 确认 信息 ，DROP DATABASE 声明 删除 数据 库 后 ,数据 库 中 存储 的 所 有 数据 表 和 


提 示 。 数据 也 将 一 同 被 删除 ， 而 且 不 能 恢复 。 


15.3 ”实战 演练 一 一 数据 库 的 创建 和 删除 
本 章 分 别 介绍 了 数据 库 的 基本 操作 ， 包 括 数据 库 的 创建 、 查 看 当前 数据 库 和 删除 数据 库 。 最 


后 介绍 了 MySQL 中 各 种 存储 引擎 。 在 这 里 ， 通 过 一 个 案例 ， 让 读者 全 面 回顾 数据 库 的 基本 操作 。 


1. 案例 目的 

登录 MySQL， 使 用 数据 库 操作 语句 创建 、 查 看 和 删除 数据 库 ， 步 骤 如 下 : 
(1) 登录 数据 库 。 

(2) 创建 数据 库 zoo。 

(3) 选择 当前 数据 库 为 zoo， 并 查看 zoo 数据 库 的 信息 。 

(4) 删除 数据 库 zoo。 

2. 案例 操作 过 程 

登录 数据 库 。 

打开 Windows 命令 行 ， 输 入 登录 用 户 名 和 密码 。 


C:\>mysql -h localhost -u root -p 
Enter password: ** 


或 者 打开 MySQL 5.7 Command Line Client， 只 用 输入 用 户 密 码 也 可 以 登录 。 登 录 成 功 后 显示 


如 下 信息 : 


Welcome to the MySQL monitor. Commands end with ; or \g. 

Your MySQL connection id is 2 

Server version: 5.7.10 MySQL Community Server (GPL) 

Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. 
Oracle is a registered trademark of Oracle Corporation and/or its 
affiliates. Other names may be trademarks of their respective 

owners. 


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement . 


mysql> 


出 现 MySQL 命令 输入 提示 符 时 表示 登录 成 功 ， 可 以 输入 SQL 语句 进行 操作 。 
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辆 创建 数据 库 zo0， 执 行 过 程 如 下 。 


mysql> CREATE DATABASE zoo7 
Query OK, 1 row affected (0.01 sec) 


提示 信息 表明 语句 成 功 执行 。 
查看 当前 系统 中 所 有 的 数据 库 ， 执 行 过 程 如 下 。 


mysql> SHOW DATABASES; 


information schema | 
mysql | 
Performance _ schema | 
test | 
sakila | 


可 以 看 到 ， 数 据 库 列表 中 已 经 有 了 名 称 为 zoo 数据 库 ， 数 据 库 创建 成 功 。 
加 选择 当前 数据 库 为 zo0， 查 看 数据 库 zoo 的 信息 ， 执 行 过 程 如 下 。 


mysql> USE zoo7 
Database changed 


提示 信息 Database changed 表明 选择 成 功 。 
查看 数据 库 信 息 ， 如 下 所 示 : 


mysql> SHOW CREATE DATABASE zoo \G 
六 太太 ] 。 IOW 太太 
Database: zoo 
Create Database: CREATE DATABASE ‘zo00. /*!40100 DEFAULT CHARACTER SET utf8 */ 


Database 值 表明 当前 数据 库 名 称 ，Create Database 值 表示 创建 数据 库 zoo 的 语句 ， 后 面 为 注释 
信息 。 


加 删除 数据 库 zoo， 执 行 过 程 如 下 。 


mysql> DROP DATABASE zoo; 
Query OK, 0 rows affected (0.00 sec) 


语句 执行 完毕 ， 将 数据 库 zoo 从 系统 中 删除 。 
mysql> SHOW DATABASES; 


二 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 
| Database 1 

二 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 
| information schema | 

| mysql 1 
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Performance schema | 
test | 
sakila 1 


可 以 看 到 ， 数 据 库 列表 中 已 经 没有 名 称 为 zoo 的 数据 库 了 。 


15.4 高 手 私房 菜 


技巧 1: 什么 是 MySQL 存储 引擎 ? 


MySQL 提供 了 多 个 不 同 的 存储 引擎 ,包括 处 理事 务 安 全 表 的 引擎 和 处 理 非 事务 安全 表 的 引擎 。 
在 MySQL 中 ， 不 需要 在 整个 服务 器 中 使 用 同一 种 存储 引擎 ， 针 对 具体 的 要 求 ， 可 以 对 每 一 个 表 使 
用 不 同 的 存储 引擎 .MySQL 5.7 支持 的 存储 引擎 有 : InnoDB,，MyISAM,，Memory，Merge，Archive， 
Federated，CSV，BLACKHOLE 等 。 可 以 使 用 SHOW ENGINES 语句 查看 系统 所 支持 的 引擎 类 型 ， 
结果 如 下 。 
mysql> SHOW ENGINES \G 
| row 次 炎炎 
Engine: FEDERATED 
Support: NO 
Comment: Federated MYSQL storage engine 
Transactions: NULL 
XA: NULL 
Savepoints: NULL 
关 交 次 人 row 六 火 类 
Engine: MRG MYISAM 
Support: YES 
Comment: Collection of identical MyISAM tables 
Transactions: NO 
XA: NO 
Savepoints: NO 
类 交火 3 IOW 大 炎炎 
Engine: MyISAM 
Support: YES 
Comment: MyISAM storage engine 
Transactions: NO 
XA: NO 
Savepoints: NO 
灵 赤 炎 月。 工 OW 太太 办 
Engine: BLACKHOLE 
Support: YES 
Comment: /dev/null storage engine (anything you write to it disappears) 
Transactions: NO 
XA: NO 
Savepoints: NO 
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六 炎炎 喇 。 OW 大 炎 灵 
Engine: CSV 
Support: YES 
Comment: CSV storage engine 
Transactions: NO 
XA: NO 
Savepoints: NO 
www 日 。 TOW 妆 炎 克 
Engine: MEMORY 
Support: YES 
Comment: Hash based, stored in memory, useful for temporary tables 
Transactions: NO 
XA: NO 
Savepoints: NO 
太太 了 。 IOW * 太 太 
Engine: ARCHIVE 
Support: YES 
Comment: Archive storage engine 
Transactions: NO 
XA: NO 
Savepoints: NO 
大 炎炎 日 。 row 交火 类 
Engine: InnoDB 
Support: DEFAULT 
Comment: Supports transactions, row-level locking, and foreign keys 
Transactions: YES 
XA: YES 
Savepoints: YES 
交 交 次 9。 row 交火 类 
Engine: PERFORMANCE SCHEMA 
Support: YES 
Comment: Performance Schema 
Transactions: NO 
XA: NO 
Savepoints: NO 
9 rows in set (0.00 sec) 


Support 列 的 值 表 示 某 种 引擎 是 否 能 使 用 : YES 表示 可 以 使 用 ，NO 表示 不 能 使 用 DEFAULT 
表示 该 引擎 为 当前 默认 存储 引擎 。 


15.5 经典 习题 
(1) 查看 当前 系统 中 的 数据 库 。 


(2) 创建 数据 库 Book， 使 用 SHOW CREATE DATABASE 语句 查看 数据 库 定义 信息 。 
(3) 删除 数据 库 Book。 


第 16 章 数据 表 的 基本 操作 


在 数据 库 中 ， 数 据 表 是 数据 库 中 最 重要 、 最 基本 的 操作 对 象 ， 是 数据 存储 的 基本 单位 。 数 据 
表 被 定义 为 列 的 集合 , 数据 在 表 中 是 按照 行 和 列 的 格式 来 存储 的 。 每 一 行 代表 一 条 唯一 的 记录 , 每 
一 列 代表 记录 中 的 一 个 域 。 

本 章 将 详细 介绍 数据 表 的 基本 操作 ， 主 要 内 容 包 括 : 创建 数据 表 、 查 看 数据 表 结构 、 修 改 数 
据 表 、 删 除数 据 表 。 通 过 本 章 的 学 习 ， 读 者 能 够 熟练 掌握 数据 表 的 基本 概念 ， 理 解约 束 、 默 认 和 规 
则 的 含义 并 且 学 会 运用 ;能 够 在 图 形 界面 模式 和 命令 行 模式 下 熟练 地 完成 有 关 数 据 表 的 常用 操作 。 
本 章 学 习 目 标 

@ ”掌握 如 何 创建 数据 表 
掌握 查看 数据 表 结构 的 方法 
掌握 如 何 修改 数据 表 
熟悉 删除 数据 表 的 方法 
熟练 操作 综合 案例 数据 表 的 基本 操作 


16.1 创建 数据 表 


在 创建 完 数据 库 之 后 ， 接 下 来 的 工作 就 是 创建 数据 表 。 所 谓 创建 数据 表 ， 指 的 是 在 已 经 创建 
好 的 数据 库 中 建立 新 表 。 创建 数据 表 的 过 程 是 规定 数据 列 的 属性 的 过 程 , 同时 也 是 实施 数据 完整 性 
(包括 实体 完整 性 、 引 用 完整 性 和 域 完整 性 等 约束 的 过 程 。 本 节 将 介绍 创建 数据 表 的 语法 形式 、 
如 何 添加 主键 约束 、 外 键 约束 、 非 空 约束 等 。 


16.1.1 创建 表 的 语法 形式 


数据 表 属 于 数据 库 ， 在 创建 数据 表 之 前 ， 应 该 使 用 语句 “USE < 数据 库 名 >” 指 定 操作 是 在 哪 
个 数据 库 中 进行 ， 如 果 没 有 选择 数据 库 ， 会 抛 出 “No database selected” 的 错误 。 
创建 数据 表 的 语句 为 CREATE TABLE， 语 法 规则 如 下 : 





使 用 CREATE TABLE 创建 表 时 ， 必 须 指 定 以 下 信息 : 
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(1) 要 创建 的 表 的 名 称 , 不 区 分 大 小 写 , 不 能 使 用 SQL 语言 中 的 关键 字 , 如 DROP、ALTER、 
INSERT 等 。 
(2) 数据 表 中 每 一 个 列 〈 字 段 ) 的 名 称 和 数据 类 型 ， 如 果 创建 多 个 列 ， 要 用 逗号 隔 开 。 
【 例 16.1】 创 建 员工 表 tb_emp1， 结 构 如 表 16-1 所 示 。 
表 16-1 tb_emp1 表 结 构 
字段 名 称 数据 类 型 
i INT(11) 员工 编号 





VARCHAR(25) 员工 名 称 
INT(11) 所 在 部 门 编号 
FLOAT 工资 

首先 创建 数据 库 ，SQL 语句 如 下 : 

CREATE DATABASE test _ db; 

选择 创建 表 的 数据 库 ，SQL 语句 如 下 : 

USE test_ db; 











创建 tb_empl 表 ，SQL 语句 为 : 
CREATE TABLE tb_ empl 

( 

id INT(11), 

name VARCHAR(25), 
deptId INT(11), 

salary FLOAT 

) 7 


语句 执行 后 ， 便 创建 了 一 个 名 称 为 tb_emp1 的 数据 表 ， 使 用 SHOW TABLES; 语 句 查 看 数据 表 
是 否 创建 成 功 ，SQL 语句 如 下 : 
mysql> SHOW TABLES; 


+----------------------- + 
| Tables in_ test db | 
+---------------------- + 
| tb_empl 1 
+---------------------- + 


1 row in set (0.00 sec) 
可 以 看 到 ，test_db 数据 库 中 已 经 有 了 数据 表 tb_tmp1， 数 据 表 创建 成 功 。 


16.1.2 ”使 用 主键 约束 


主键 ， 又 称 主 码 ， 是 表 中 一 列 或 多 列 的 组 合 。 主 键 约束 (Primary Key Constraint) 要求 主键 列 
的 数据 唯一 , 并 且 不 允许 为 空 。 主 键 能 够 惟一 地 标识 表 中 的 一 条 记录 , 可 以 结合 外 键 来 定义 不 同 数 
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据 表 之 间 的 关系 , 并 且 可 以 加 快 数据 库 查 询 的 速度 。 主键 和 记录 之 间 的 关系 如 同 身份 证 和 人 之 间 的 
关系 ， 它 们 之 间 是 一 一 对 应 的 。 主 键 分 为 两 种 类 型 : 单字 段 主键 和 多 字段 联合 主键 。 


1. 单字 段 主 键 

主键 由 一 个 字段 组 成 ，SQL 语句 格式 分 为 以 下 两 种 情况 。 
(1) 在 定义 列 的 同时 指定 主键 ， 语 法 规则 如 下 : 

字段 名 数据 类 型 PRIMARY KEY [默认 值 ] 


【 例 16.2】 定 义 数据 表 tb_emp 2， 其 主键 为 id，SQL 语句 如 下 : 


CREATE TABLE tb _ emp2 

( 

id INT (11) PRIMARY KEY, 
name VARCHAR (25), 

deptId INT(11), 

salary FLOAT 

); 


(2) 在 定义 完 所 有 列 之 后 指定 主键 。 


[CONSTRAINT < 约束 名 >] PRIMARY KEY [字段 名 ] 


【 例 16.3】 定 义 数据 表 tb_emp 3， 其 主键 为 id，SQL 语句 如 下 : 
CREATE TABLE tb_emp3 
( 
To FNP 
name VARCHAR(25), 
deptId INT(11), 
salary FLOAT, 
PRIMARY KEY (id) 
) 7 


上 述 两 个 例子 执行 后 的 结果 是 一 样 的 ， 都 会 在 id 字段 上 设置 主键 约束 。 

2. 多 字段 联合 主键 

主键 由 多 个 字段 联合 组 成 ， 语 法 规则 如 下 : 

PRIMARY KEY [字段 1， 字 段 2, . . .， 字 段 n] 

【 例 16.4】 定 义 数据 表 tb_emp4， 假 设 表 中 间 没 有 主键 id， 为 了 唯一 确定 一 个 员工 ， 可 以 把 
name、deptId 联合 起 来 做 为 主键 ，SQL 语句 如 下 : 


CREATE TABLE tb_empP4 
( 

name VARCHAR(25), 

deptId INT(11), 

salary FLOAT, 
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PRIMARY KEY (name,deptId) 
用 


语句 执行 后 ， 便 创建 了 一 个 名 称 为 tb_emp4 的 数据 表 ，name 字段 和 deptld 字段 组 合 在 一 起 成 
为 tb_emp4 的 多 字段 联合 主键 。 


16.1.3 ”使 用 外 键 约束 


外 键 用 来 在 两 个 表 的 数据 之 间 建 立 链接 ， 它 可 以 是 一 列 或 者 多 列 。 一 个 表 可 以 有 一 个 或 多 个 
外 键 。 外 键 对 应 的 是 参照 完整 性 ,一 个 表 的 外 键 可 以 为 空 值 ， 若 不 为 空 值 ， 则 每 一 个 外 键 值 必须 等 
于 另 一 个 表 中 主键 的 某 个 值 。 

外 键 : 首先 它 是 表 中 的 一 个 字段 ， 它 可 以 不 是 本 表 的 主键 ， 但 对 应 另外 一 个 表 的 主键 。 外 键 
主要 作用 是 保证 数据 引用 的 完整 性 , 定义 外 键 后 , 不 允许 删除 在 另 一 个 表 中 具有 关联 关系 的 行 。 外 
键 的 作用 是 保持 数据 的 一 臻 性、 完整 性 。 例 如 ， 部 门 表 tb_dept 的 主键 是 id， 在 员工 表 tb_emp5 中 
有 一 个 键 deptId 与 这 个 id 关联 。 

主 表 ( 父 表 ) : 对 于 两 个 具有 关联 关系 的 表 而 言 ， 相 关联 字段 中 主键 所 在 的 那个 表 即 是 主 表 。 

从 表 ( 子 表 ) : 对 于 两 个 具有 关联 关系 的 表 而 言 ， 相 关联 字段 中 外 键 所 在 的 那个 表 即 是 从 表 。 

创建 外 键 的 语法 规则 如 下 : 

[CONSTRAINT < 外 键 名 >] FOREIGN KEY 字段 名 1 [ ,字段 名 2,…] 

REFERENCES < 主 表 名 > 主键 列 1 [ ,主键 列 2,…] 


“外 键 名 ”为 定义 的 外 键 约束 的 名 称 ， 一 个 表 中 不 能 有 相同 名 称 的 外 键 ; “字段 名 ”表示 子 
表 和 需要 添加 外 键 约束 的 字段 列 ; “ 主 表 名 ” 即 被 子 表 外 键 所 依赖 的 表 的 名 称 ; “主键 列 ” 表 示 主 表 
中 定义 的 主键 列 ， 或 者 列 组 合 。 
【 例 16.5】 定 义 数据 表 tb_emp5， 并 在 tb_emp5 表 上 创建 外 键 约束 。 
创建 一 个 部 门 表 tb_deptl， 表 结构 如 表 16-2 所 示 ，SQL 语句 如 下 : 
表 16-2 tb_dept1 表 结 构 
字段 名 称 数据 类 型 备注 





























location VARCHAR(50) 部 门 位 置 





CREATE TABLE tb deptl 

( 

id INT(11) PRIMARY KEY, 
name VARCHAR(22) NOT NULL, 
location VARCHAR(50) 

); 


定义 数据 表 tb_emp5， 让 它 的 键 deptId 作为 外 键 关联 到 tb_deptl 的 主键 id，SQL 语句 为 : 
CREATE TABLE tb_ emp5 
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( 

be INT(11) PRIMARY KEY, 

name VARCHAR(25), 

deptId INT(11), 

salary FLOAT, 

CONSTRAINT fk emp deptl1 FOREIGN KEY (deptI1Id) REFERENCES tb deptl (id) 
jy 


以 上 语句 执行 成 功 之 后 ， 在 表 tb_emp5 上 添加 了 名 称 为 人 emp_deptl 的 外 键 约束 ， 外 键 名 称 
为 depttd， 其 依赖 于 表 tb_deptl 的 主键 id。 


【/ 关联 指 的 是 在 关系 型 数据 库 中 ， 相 关 表 之 间 的 联系 。 它 是 通过 相 容 或 相同 的 属性 或 属 

记性 组 来 表示 的 。 子 表 的 外 键 必须 关联 父 表 的 主键 ， 且 关联 字段 的 数据 类 型 必须 匹配 ， 

提 示 。 如 果 类 型 不 一 样 ， 则 创建 子 表 时 ， 就 会 出 现 错误 “ERROR 1005 (HY000): Can't create 
table 'database.tablename'(errno: 150)”。 


16.1.4 ”使 用 非 空 约束 
非 空 约束 (Not Null Constraint〉 指 字段 的 值 不 能 为 空 。 对 于 使 用 了 非 空 约束 的 字段 ， 如 果 用 
户 在 添加 数据 时 没有 指定 值 ， 数 据 库 系 统 会 报错 。 
非 空 约束 的 语法 规则 如 下 : 
字段 名 数据 类 型 not nul1 
【 例 16.6】 定 义 数据 表 tb_emp6， 指 定员 工 的 名 称 不 能 为 室 ，SQL 语句 如 下 : 


CREATE TABLE tb_emp6 

( 

id INT(11) PRIMARY KEY, 
name VARCHAR(25) NOT NULL, 
deptId INT(11), 

salary FLOAT 

); 


执行 后 ， 在 tb_emp6 中 创建 了 一 个 Name 字段 ， 其 插入 值 不 能 为 空 (NOT NULL) 。 


16.1.5 ”使 用 了 唯一 性 约束 
唯一 性 约束 〈Unique Constraint〉 要 求 该 列 唯 一 ， 允 许 为 空 ， 但 只 能 出 现 一 个 空 值 。 唯 一 性 约 
束 可 以 确保 一 列 或 者 几 列 不 出 现 重复 值 。 
唯一 性 约束 的 语法 规则 如 下 : 
(1) 在 定义 完 列 之 后 直接 指定 唯一 约束 ， 语 法 规则 如 下 : 
字段 名 数据 类 型 UNIQUE 
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【 例 16.7】 定 义 数据 表 tb_dept2， 指 定 部 门 的 名 称 唯一 ，SQL 语句 如 下 : 
CREATE TABLE tb_ dept2 
( 
Ld INT(11) PRIMARY KEY, 
name VARCHAR (22) UNIQUE, 
location VARCHAR(50) 
Wi 


(2) 在 定义 完 所 有 列 之 后 指定 唯一 约束 ， 语 法 规则 如 下 : 
[CONSTRAINT < 约束 名 >] UNIQUE (< 字段 名 >) 


【 例 16.8】 定 义 数据 表 tb_dept3， 指 定 部 门 的 名 称 唯一 ，SQL 语句 如 下 : 
CREATE TABLE tb _ dept3 
( 
id INT(11) PRIMARY KEY, 
name VARCHAR(22), 
location VARCHAR(50), 
CONSTRAINT STH UNIQUE (name) 
) 7 


UNIQUE 和 PRIMARY KEY 的 区 别 : 一 个 表 中 可 以 有 多 个 字段 声明 为 UNIQUE, 但 只 能 有 一 
个 PRIMARY KEY 声明 ; 声明 为 PRIMAY KEY 的 列 不 允许 有 空 值 ， 但 是 声明 为 UNIQUE 的 字段 
允许 空 值 (NULL) 的 存在 。 


16.1.6 ”使 用 默认 约束 


默认 约束 (Default Constraint) 指定 某 列 的 默认 值 。 如 男性 同学 较 多 , 性 别 就 可 以 默认 为 “ 男 ”。 
如 果 插 入 一 条 新 的 记录 时 没有 为 这 个 字段 赋值 ， 那 么 系统 会 自动 为 这 个 字段 赋值 为 “ 男 ”。 

默认 约束 的 语法 规则 如 下 : 

字段 名 数据 类 型 DEFAULT 默认 值 


【 例 16.9】 定 义 数据 表 tb_emp7， 指 定员 工 的 部 门 编号 默认 为 1111，SQL 语句 如 下 : 
CREATE TABLE tb_emp7 
( 
id INT(11) PRIMARY KEY, 
name VARCHAR(25) NOT NULL, 
deptId INT(11) DEFAULT 1111, 
salary FLOAT 
); 


以 上 语句 执行 成 功 之 后 ， 表 tb_emp7 上 的 字段 deptId 拥有 了 一 个 默认 的 值 1111， 新 插入 的 记 
录 如 果 没 有 指定 部 门 编号 ， 则 默认 都 为 1111。 
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16.1.7 ”设置 表 的 属性 值 自动 增加 


在 数据 库 应 用 中 ， 经 常 希望 在 每 次 插入 新 记录 时 ， 系 统 自动 生成 字段 的 主键 值 。 可 以 通过 为 
表 主 键 添加 AUTO_INCREMENT 关键 字 来 实现 。 默认 的 , 在 MySQL 中 AUTO_INCREMENT 的 初 
始 值 值 是 1， 每 新 增 一 条 记录 ,字段 值 自动 加 1。 一 个 表 只 能 有 一 个 字段 使 用 AUTO_INCREMENT 
约束 ， 且 该 字段 必须 为 主键 的 一 部 分 。AUTO_INCREMENT 约束 的 字段 可 以 是 任何 整数 类 型 
(TINYINT、SMALLIN、INT、BIGINT 等 ) 。 

设置 表 的 属性 值 自动 增加 的 语法 规则 如 下 : 

字段 名 数据 类 型 AUTO_INCREMENT 


【 例 16.10】 定 义 数据 表 tb_emp8， 指 定员 工 的 编号 自动 递增 ，SQL 语句 如 下 : 
CREATE TABLE tb_emp8 
( 
id INT(11) PRIMARY KEY AUTO_INCREMENT, 
name VARCHAR(25) NOT NULL, 
deptId INT(11), 
salary FLOAT 
); 


上 述 例子 执行 后 ， 会 创建 名 称 为 tb_emp8 的 数据 表 。 表 tb_emp8 中 的 id 字段 的 值 在 添加 记录 
的 时 候 会 自动 增加 ， 在 插入 记录 的 时 候 ， 默认 的 自 增 字段 id 的 值 从 1 开始 ， 每 次 添加 一 条 新 记录 ， 
该 值 自动 加 1。 
例如 ， 执 行 如 下 插入 语句 : 
mysql> INSERT INTO tb emp8 (name,salary) 
-> VALUES('Lucy',1000), ('Lura',1200), ('Kevin',1500); 


语句 执行 完 后 ，tb_emp8 表 中 增加 3 条 记录 ， 在 这 里 并 没有 输入 id 的 值 ， 但 系统 已 经 自动 添 
加 该 值 ， 使 用 SELECT 命令 查看 记录 ， 如 下 所 示 。 


mysql> SELECT * FROM tb emp8; 
+----+-------- 二 -一 一 一 一 一 一 一 一 一 +- 一 -一 一 一 -一 一 -一 一 + 














+ 一 一- 二 一 一 一 一 一 一 一 一 + 一 -一 -一 一 一 -一 一 + 一 一 一 一 一 一 一 一 一 一 + 
Licy | NOBG | 1000 | 
V2 1 Dara NODE | 00 
| 3 | Kevin | NULL | 1500 | 
+ 一 -+ 一 一 一 一 一 一 一 一 + 一 -一 一 一 一 一 一 -一 一 + 一 一 一 一 一 一 一 一 一 一 一 + 


3 rows in set (0.00 sec) 


C9 这 里 使 用 INSERT 声明 向 表 中 插入 记录 的 方法 ， 并 不 是 SQL 的 标准 语法 ， 这 种 语法 
不 一 定 被 其 他 的 数据 库 支持 ， 只 能 在 MySQL 中 使 用 。 


旨 | 
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16.2 查看 数据 表 结 构 


使 用 SQL 语句 创建 好 数据 表 之 后 ， 可 以 查看 表 结 构 的 定义 ， 以 确认 表 的 定义 是 否 正确 。 在 
MySQL 中 , 查看 表 结 构 可 以 使 用 DESCRIBE 和 SHOW CREATE TABLE 语句 。 本 节 将 针对 这 两 个 





语句 分 别 进行 详细 的 讲解 。 
查看 表 基 本 结构 语句 DESCRIBE 


16,2.1 


DESCRIBE/DESC 语句 可 以 查看 表 的 字段 信息 ， 其 中 包括 : 字段 名 、 字 段 数据 类 型 、 是 否 为 主 


键 、 是 否 有 默认 值 等 。 语 法 规则 如 下 : 


DESCRIBE 表 名 ; 


或 者 简写 为 : 
DESC 表 名 ; 


【 例 16.11】 分 别 使 用 DESCRIBE 和 DESC 查看 表 tb_deptl 和 表 tb_empl 的 表 结 构 。 
查看 tb_deptl 表 结 构 ，SQL 语句 如 下 : 


mysql> DESCRIBE tb deptl; 


+----------- +--------------- +-- 一 -一 一 +- 一 一 一 一 +--------- +------- + 
| Field | Type | Null | Key | Default | Extra | 
+----------- + 一 一- 一- 一 -一 -一 -一 一 +----- 一 + 一 -一 一 +--------- +------- + 
| id | int(11) | NO | PRI | NULL | | 
| name | varchar (22) | NO 1 | NULL 1 | 
| location | varchar(50) | YES | | NULL 1 | 
+----------- +---------- +-- 一 -一 一 + 一 一 一 一 +--------- +------- + 
查看 tb_empl 表 结 构 ，SQL 语句 如 下 : 

mysql> DESC tb _empl; 

+ 一 一- 一 一 一 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 +------ + 一 一 一 一 + 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 

| Field | Type | Null | Key | Default | Extra | 

+-------- 二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 +- 一 -一 一 + 一 一 一 一 一 +- 一 一 一 一 一 一 一 一 + 十 
Ia Wane CL | 4 | | NULL 1 | 

| name | varchar (25) | YES | | NULL 1 1 

1 deptId | int (11) | YES | | NULL | | 

| salary | float lxes 1 | NULL 1 1 

+ 一 -一 -一 一 一 一 二 -一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 -一 一 + 一 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 + 


其 中 ， 各 个 字段 的 含义 分 别 解释 如 下 : 


@ Null: 表示 该 列 是 否 可 以 存储 Null 值 。 

@ Key: 表示 该 列 是 否 已 编制 索引 。 PRI 表示 该 列 是 表 主 键 的 一 部 分 ; UNI 表 示 该 列 是 UNIQUE 
索引 的 一 部 分 ; MUL 表示 在 列 中 茶 个 给 定 值 允许 出 现 多 次 。 

@ 。 Default: 表示 该 列 是 否 有 默认 值 ， 如 果 有 的 话 值 是 多 少 。 

@ ”Extra: 表示 可 以 获取 的 与 给 定 列 有 关 的 附加 信息 ， 例 如 AUTO_INCREMENT 等 。 
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16.2.2 ”查看 表 详 细 结 构 语句 SHOW CREATE TABLE 
SHOW CREATE TABLE 语句 可 以 用 来 显示 创建 表 时 的 CREATE TABLE 语句 ， 语 法 格式 如 


SHOW CREATE TABLE < 表 名 \G>; 


C7 使 用 SHOW CREATE TABLE 语句 ， 不 仅 可 以 查看 表 创建 时 候 的 详细 语句 ， 而 且 还 可 
以 查看 存储 引擎 和 字符 编码 。 

示 

如 果 不 加 '“G” 参数， 显示 的 结果 可 能 非常 混乱 ， 加 上 参数 \G” 之 后 ， 可 使 显示 结果 更 加 
直观 ， 易 于 查看 。 


【 例 16.12】 使 用 SHOW CREATE TABLE 查看 表 tb_empl 的 详细 信息 ，SQL 语句 如 下 : 


mysql> SHOW CREATE TABLE tb empl; 


| Table | Create Table 


| fruits | CREATE TABLE ‘fruits. ( 

‘f£ id char(10) NOT NULL, 

`“s_id ”int(11) NOT NULL, 

`“f_name” char (255) NOT NULL, 

‘f£ price’ ”decimal(8,2) NOT NULL, 

PRIMARY KEY (‘f id`)， 

KEY ‘index name” (‘f name'), 

KEY “index id price (‘f id','‘f price `) 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 | 





使 用 参数 “(G” 之 后 的 结果 如 下 : 


mysql> SHOW CREATE TABLE tb empl\G 
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六 交大 了。 工 OW 太太 妇 
Table: tb empl 
Create Table: CREATE TABLE ‘tb empl. ( 
“id* int(11) DEFAULT NULL, 
“name ”varchar (25) DEFAULT NULL, 
‘deptId. int(11) DEFAULT NULL, 
“salary. float DEFAULT NULL 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 
1 row in set (0.00 sec) 


16.3 ”修改 数据 表 


修改 表 指 的 是 修改 数据 库 中 已 经 存在 的 数据 表 的 结构 MySQL 使 用 ALTER TABLE 语句 修改 
表 。 常 用 的 修改 表 的 操作 有 : 修改 表 名 、 修 改 字段 数据 类 型 或 字段 名 、 增 加 和 删除 字段 、 修 改 字段 
的 排列 位 置 ， 更 改 表 的 存储 引擎 ， 删 除 表 的 外 键 约束 等 。 本 节 将 对 和 修改 表 有 关 的 操作 进行 讲解 。 


16.3.1 修改 表 名 
MySQL 是 通过 ALTER TABLE 语句 来 实现 表 名 的 修改 的 ， 具 体 的 语法 规则 如 下 : 
ALTER TABLE < 旧 表 名 > RENAME [TO] < 新 表 名 >; 
其 中 TO 为 可 选 参数 ， 使 用 与 否 均 不 影响 结果 。 
【 例 16.13】 将 数据 表 tb_dept3 改名 为 tb_deptment3。 


执行 修改 表 名 操作 之 前 ， 使 用 SHOW TABLES 查看 数据 库 中 所 有 的 表 。 
mysql> SHOW TABLES; 


| tb_dept 1 
| tb_dept2 1 
| tb_dept3 1 


使 用 ALTER TABLE 将 表 tb_dept3 改名 为 tb_deptment3，SQL 语句 如 下 : 


ALTER TABLE tb_dept3 RENAME tb deptment3; 


语句 执行 之 后 ， 检 验 表 tb_dept3 是 否 改名 成 功 。 使 用 SHOW TABLES 查看 数据 库 中 的 表 ， 结 
果 如 下 : 


mysql> SHOW TABLES; 


+--------------------- + 
| Tables_ in test db 1 
+--------------------- 十 
| tb_dept 1 
| tb_dept2 | 
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| tb_deptment3 1 


经 过 比较 可 以 看 到 ， 数 据 表 列表 中 已 经 有 了 名 称 为 tb_deptment3 的 表 。 


读者 可 以 在 修改 表 名 称 时 使 用 DESC 命令 查看 修改 前 后 两 个 表 的 结构 ， 修 改 表 名 并 不 


提 示 


16.3.2 ”修改 字段 的 数据 类 型 


修改 表 的 结构 ， 因 此 修改 名 称 后 的 表 和 修改 名 称 前 的 表 的 结构 必然 是 相同 的 。 


修改 字段 的 数据 类 型 ， 就 是 把 字段 的 数据 类 型 转换 成 另 一 种 数据 类 型 。 在 MySQL 中 修改 字段 


数据 类 型 的 语法 规则 如 下 : 


ALTER TABLE < 表 名 > MODIFY < 字段 名 > < 数据 类 型 > 


其 中 “ 表 名 ” 指 要 修改 数据 类 型 的 字段 所 在 表 的 名 称 ， 
据 类 型 ” 指 修改 后 字段 的 新 数据 类 型 。 


“字段 名 ” 指 需 要 修改 的 字段 ，“ 数 


【 例 16.14】 将 数据 表 tb_deptl 中 name 字段 的 数据 类 型 由 VARCHAR(22) 修 改 成 


VARCHAR(30)。 


执行 修改 表 名 操作 之 前 ， 使 用 DESC 查看 tb_dept 表 结 构 ， 结 果 如 下 : 


mysql> DESC tb deptl; 


+---------- +--------------- +--------- +-------- +------------- +------- + 
| Field | Type | Null | Extra | 

+---------- +--------------- +--------- +-------- +------------- +------- + 
| id InEdIA 1 1 

| name | varchar (22) | YES 1 


| Location | varchar (50) 


3 rows in set (0.00 sec) 


可 以 看 到 现在 name 字段 的 数据 类 型 为 VARCHAR(22), 下 面 修改 其 类 型 。 输入 如 下 SQL 语句 


并 执行 : 


ALTER TABLE tb deptl MODIFY name VARCHAR(30); 


再 次 使 用 DESC 查看 表 ， 结 果 如 下 : 














mysql> DESC tb deptl; 


Ia | :int(11) 
| name | varchar (30) 
| location | varchar (50) 


+ 一 一 -一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 一 一 +- 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 一 +- 一 -一 一 -一 + 


3 rows in set (0.00 sec) 
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语句 执行 之 后 ,检验 会 发 现 表 tb_dept 表 中 name 字 段 的 数据 类 型 已 经 修改 成 了 VARCHAR(30)， 
修改 成 功 。 
16.3.3 ”修改 字段 名 

MySQL 中 修改 表 字 段 名 的 语法 规则 如 下 : 

ALTER TRBLE < 表 名 > CHANGE < 旧 字 段 名 > < 新 字段 名 > < 新 数据 类 型 >; 


其 中 ，“ 旧 字段 名 ” 指 修改 前 的 字段 名 ; “新 字段 名 ” 指 修改 后 的 字段 名 ; “新 数据 类 型 ” 
指 修改 后 的 数据 类 型 ,如 果 不 需 要 修改 字段 的 数据 类 型 , 可 以 将 新 数据 类 型 设置 成 与 原来 一 样 即 可 ， 
但 数据 类 型 不 能 为 空 。 


【 例 16.15 】 将 数据 表 tb_deptl 中 的 location 字段 名 称 改 为 loc， 数 据 类 型 保持 不 变 ，SQL 语句 
如 下 : 
ALTER TABLE tb_dept1 CHANGE location loc VRRCHRR (50) 
使 用 DESC 查看 表 tb_deptl， 会 发 现 字段 的 名 称 已 经 修改 成 功 ， 结 果 如 下 : 
mysql> DESC tb deptl; 


+---------- +--------------- +--- 一 -一 +-------- +------------- +------- + 
| Field | Type | Null | Key 1Default | Extra | 
+---------- +--------------- +--------- +-------- +------------- +------- 十 
Jia Udine(LLy | NO | PRI | NULL 1 1 
| name | varchar (30) | YES 1 | NULL | | 
Wo | varchar (50) | YES | | NULL | | 
+---------- +--------------- +-------- + 一 一 一 一 一 一 一 一 一 +--- 一 -一 一- 一 +------- + 


3 rows in set (0.00 sec) 


【 例 16.16】 将 数据 表 tb_deptl 中 的 loc 字段 名 称 改 为 location， 同 时 将 数据 类 型 变 为 
VARCHAR(60)，SQL 语句 如 下 : 
ALTER TABLE tb _ deptl1 CHANGE loc location VARCHAR(60); 
使 用 DESC 查看 表 tb_deptl， 会 发 现 字段 的 名 称 和 数据 类 型 均 已 经 修改 成 功 ， 结 果 如 下 : 
mysql> DESC tb deptl1; 


+ 一 一 一 一 一 一 一 一 +--------------- +- 一 一 一 一 一 一 一 一 +-------- +------------- +------- + 
| Field | Type | Null | Key 1Default | Extra | 
+---------- +--------------- +--------- +-------- +------------- +------- + 
| id 人 Et 人 IIL) | NO | PRI | NULL | | 

| name | varchar (30) | YES 1 | NULL 1 1 

| Location | varchar (60) | YES 1 | NULL 1 1 
+ 一 一 一 一 一 一 一 一 一 一 +--------------- +- 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 一 +------- + 


3 rows in set (0.00 sec) 


0! CHANGE 也 可 以 只 修改 数据 类 型 ,实现 和 MODIFY 同样 的 效果 , 方法 是 将 SQL 语句 
提示 中 的 “新 字段 名 ”和 “ 旧 字 段 名 ”设置 为 相同 的 名 称 ， 只 改变 “数据 类 型 ”。 
a 
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由 于 不 同类 型 的 数据 在 机 器 中 存储 的 方式 及 长 度 并 不 相同 ， 修 改 数据 类 型 可 能 会 影响 到 数据 
表 中 己 有 的 数据 记录 。 因 此 ， 当 数据 库 表 中 已 经 有 数据 时 ， 不 要 轻易 修改 数据 类 型 。 


16.3.4 添加 字段 
随 着 业务 需求 的 变化 ， 可 能 需要 在 已 经 存在 的 表 中 添加 新 的 字段 。 一 个 完整 字段 包括 字段 名 、 
数据 类 型 、 完 整 性 约束 。 添 加 字段 的 语法 格式 如 下 : 


ALTER TABLE < 表 名 > ADD < 新 字段 名 > < 数据 类 型 > 
[约束 条 件 ] [FIRST | AFTER 已 存在 字段 名 ] ; 


新 字段 名 为 需要 添加 的 字段 的 名 称 ; “FIRST” 为 可 选 参数 ， 其 作用 是 将 新 添加 的 字段 设置 为 
表 的 第 一 个 字段 ， “AFTER” 为 可 选 参数 ， 其 作用 是 将 新 添加 的 字段 添加 到 指定 的 “已 存在 字段 
名 ”的 后 面 。 











CY “FIRST” 或 “AFTER 已 存在 字段 名 ”用 于 指定 新 增 字段 在 表 中 的 位 置 ， 如果 SQL 
提示 语句 中 没有 这 两 个 参数 ， 则 默认 将 新 添加 的 字段 设置 为 数据 表 的 最 后 列 。 
1 \ 


1. 添加 无 完整 性 约束 条 件 的 字段 
【 例 16.17】 在 数据 表 tb_deptl 中 添加 一 个 没有 完整 性 约束 的 INT 类 型 的 字段 managerld (部 
门 经 理 编号 ) ，SQL 语句 如 下 : 
ALTER TABLE tb_ deptl ADD managerId INT(10); 
使 用 DESC 查看 表 tb_dept1, 会 发 现在 表 的 最 后 添加 了 一 个 名 为 managerld 的 INT 类 型 的 字段 ， 
结果 如 下 : 


mysql> DESC tb deptl; 


+------------- 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 -一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 +------------- +-------- 
再 

| Field | Type | Null | Key | Default | Extra | 

+---- 一 -一 -一 一 -一 十 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一- 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 +------------- +-------- 
+ 

Wa | | NO | PR | NULL 1 1 

| name | varchar(30) | YES 人 | NULL | | 

| location | varchar(60) | YES 1 | NULL | | 

| managerId | int(10) | YES | | NULL | 1 

+------------- +---------------- + 一 一 一 -一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 +------------- +-------- 
本 


4 rows in set (0.03 sec) 


2. 添加 有 完整 性 约束 条 件 的 字段 


【 例 16.18】 在 数据 表 tb_deptl 中 添加 一 个 不 能 为 空 的 VARCHAR(12) 类 型 的 字段 columnl， 
SQL 语句 如 下 : 


ALTER TABLE tb deptl1 ADD columnl1 VARCHAR(12) not null; 
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使 用 DESC 查看 表 tb_deptl1， 会 发 现在 表 的 最 后 添加 了 一 个 名 为 columnl 的 VARCHAR(12) 
类 型 且 不 为 空 的 字段 ， 结 果 如 下 : 


mysql> DESC tb deptl; 


+----------- + 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 -一 -一 -一 一 +--- 一 -一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 + 
| Field | Type | Null | Key | Default | Extra | 

+----------- +----------------- +------ 一 -一 +--- 一 -一 一- + 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一- 一 一 一 一 一 一 + 
[ee | | NO | PRI | NULL 1 1 

| name | varchar(30) | YES 1 | NULL | 1 

| location | varchar(60) | YES | | NULL | | 

| managerId | int(10) | YES 1 | NULL 1 | 

| column1l | varchar (12) | NO 1 | NULL 1 1 

+------------ +---------------- +--------- 一 一 +- 一 一 一 一 一 一 一 +------------- +-------- 十 


5 rows in set (0.00 sec) 

3. 在 表 的 第 一 列 添加 一 个 字段 

【 例 16.19】 在 数据 表 tb_deptl 中 添加 一 个 INT 类 型 的 字段 column2，SQL 语句 如 下 : 
ALTER TABLE tb_dept1 ADD column2 INT(11) FIRST; 


使 用 DESC 查看 表 tb_deptl, 会 发 现在 表 第 一 列 添加 了 一 个 名 为 column2 的 INT(11) 类 型 字段 ， 
结果 如 下 : 


mysql> DESC tb deptl; 


+------------- +--------------- +---------- +-------- +-- 一 一- 一 -一 一 一 一 + 一 一 -一 一 一 一 + 
| Field | Type | Null | Key | Default | Extra | 
+------------- +--------------- +--------- 一 +---- 一 -一 +- 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 + 
| column2 | int(11) | YES | | NULL | | 

Ia Dnt(lL) | NO | PRI | NULL 1 1 

| name | varchar (30) | YES 1 | NULL | | 

| location | varchar(60) | YES 1 | NULL | | 

| managerId | int(10) 1 YES | | NULL | | 

| column1l | varchar (12) | NO | | NULL 1 1 

+-------------- +-------------- +---------- + 一 一 一 一 一 +------------- +-------- + 


6 rows in set (0.00 sec) 
4. 在 表 的 指定 列 之 后 添加 一 个 字段 
【 例 16.20】 在 数据 表 tb_deptl 中 name 列 后 添加 一 个 INT 类 型 的 字段 column3，SQL 语句 如 


ALTER TABLE tb deptl1 ADD column3 INT(11) AFTER name; 


使 用 DESC 查看 表 tb deptl， 结 果 如 下 : 
mysql> DESC tb deptl; 


+--------- 一 -一 +----------------- + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 +------ 一 -一 -一 +-------- + 
| Field | Type | Null 1 Key | Default | Extra | 
+-- 一 -一 一- 一 +- 一 一- 一 -一 -一 一 一 一 一- 一 一 一 + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 +-- 一 -一 -一 一- 一 + 一- 一- + 
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| column2 | int(11) 1 YES || | NULL 1 | 

| id Eee | NO | PRI | NULL || 1 

| name | varchar(30) | YES 1 | NULL | 1 

| column3 | int(11) 1 YES 1 | NULL 1 | 

| location | varchar(60) | YES | | NULL | 1 

| managerId | int(10) | YES | | NULL 1 | 

| column1l | varchar (12) | NO | | NULL 1 1 

+------------ +---------------- +----------- +-— 一 一 一 一 一 一 +------------- +-------- 十 





7 rows in set (0.03 sec) 
可 以 看 到 , tb_deptl 表 中 增加 了 一 个 名 称 为 column3 的 字段 , 其 位 置 在 指定 的 name 字段 后 面 ， 
添加 字段 成 功 。 
16.3.5 ”删除 字段 
删除 字段 是 将 数据 表 中 的 某 个 字段 从 表 中 移 除 ， 语 法 格式 如 下 : 
ALTER TABLE < 表 名 > DROP < 字段 名 >; 
“字段 名 ” 指 需要 从 表 中 删除 的 字段 的 名 称 。 
【 例 16.21】 删 除数 据 表 tb_deptl 表 中 的 column2 字段 。 
首先 ， 执 行 删除 字段 之 前 ， 使 用 DESC 查看 tb_deptl 表 结 构 ， 结 果 如 下 : 
mysql> DESC tb deptl; 


+------------- 十 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 +--- 一 -一 一- 一 +-------- 二 人 4 
| Field | Type | Null | Key | Default | Extr | 
+------------- 二 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 +--- 一 -一 一- 一 +-------- + 一 一 一 一 一 一 一 一 一 一 一 一 二 -一 一 一 一 一 一 一 十 
| column2 | int(11) | YES 1 | NULL 1 | 

[| I ime | NO | PRI | NULL | 1 

| name | varchar(30) | YES | | NULL | | 

| column3 | int(11) | YES 1 | NULL | | 

| location | varchar(60) [ES | NULL | | 

| managerId | int(10) 1 YES 1 | NULL 1 | 

| column1l | varchar (12) | NO 1 | NULL 1 1 

+-------------- +-------------- +----------- + 一 -一 一 一 一 Se 省 一 二 二 二 二 = 二 二 二 


6 rows in set (0.03 sec) 


删除 column2 字段 ，SQL 语句 如 下 : 

ALTER TABLE tb_dept1l DROP column2; 
再 次 使 用 DESC 查看 表 tb_dept1， 结 果 如 下 : 
mysql> DESC tb deptl; 


+------------ 一 十 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 +---- 一 -一 -一 -一 一 +-------- + 
| Field | Type | Null | Key | Default LL Exztr | 

+------------ 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 +---- 一 -一 -一 -一 一 + 一 -一 + 
[Js | | NO | PRI | NULL 1 1 
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| name | varchar(30) | YES [| | NULL | 1 

| column3 | int(11) 1 YES | | NULL | | 

| location | varchar (60) 1 YES | | NULL | | 

| managerId | int(10) 1 YES 1 | NULL | 1 

| column1l | varchar (12) | NO | | NULL 1 1 

+ 一- 一 一 一 一 一 一 一 一 一 一 一 一 二- 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 -一 一 一 一 一 一 + 一 一 一 一 一 一 一 +------------- +-------- + 


6 rows in set (0.03 sec) 

可 以 看 到 ，tb_deptl 表 中 已 经 不 存在 名 称 为 column2 的 字段 ， 删 除 字段 成 功 。 
16.3.6 ”修改 字段 的 排列 位 置 

对 于 一 个 数据 表 来 说 ， 在 创建 的 时 候 ， 字 段 在 表 中 的 排列 顺序 就 已 经 确定 了 。 但 表 的 结构 并 
不 是 完全 不 可 以 改变 的 ， 可 以 通过 ALTER TABLE 来 改变 表 中 字段 的 相对 位 置 。 语 法 格式 如 下 : 

ALTER TABLE < 表 名 > MODIFY < 字段 1> < 数据 类 型 > FIRST|AFTER < 字段 2>; 

“字段 1” 指 要 修改 位 置 的 字段 ，“ 数 据 类 型 ” 指 “ 字 段 1” 的 数据 类 型 ，“FIRST” 为 可 选 
参数 ， 指 将 “字段 1” 修 改 为 表 的 第 一 个 字段 ， “AFTER 字段 2” 指 将 “字段 1” 插 入 到 “字段 2” 
后 面 。 

1. 修改 字段 为 表 的 第 一 个 字段 

【 例 16.22】 将 数据 表 tb_deptl 中 的 columnl 字段 修改 为 表 的 第 一 个 字段 ，SQL 语句 如 下 : 

ALTER TABLE tb_dept1 MODIFY column1l VARCHAR(12) FIRST; 

使 用 DESC 查看 表 tb_deptl1， 发 现 字段 columnl 已 经 被 移 至 表 的 第 一 列 ， 结 果 如 下 : 

mysql> DESC tb deptl; 


+------------ +----------------- + 一 一 一 一 一 一 一 一 一 +-------- +------------- +-------- 十 
| Field | Type | Null | Key | Default | Extra | 

+------------ +-----------------: + 一 一 一 一 一 一 一 一 一 一 +- 一 一 一 一 一 一 一 +------------- +-------- 十 
| column1l | varchar (12) | NO | | NULL 1 1 

| id | int(11) | NO | PRI | NULL | 1 

| name | varchar(30) | YES 1 | NULL | | 

| column3 | int(11) | YES | | NULL 1 | 

| location | varchar(60) | YES | | NULL | | 

| managerId | int(10) | YES | | NULL | | 

+------------ + 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 -一 -一 一 一 一 一 一 + 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 一 +-------- + 


6 rows in set (0.03 sec) 
2. 修改 字段 到 表 的 指定 列 之 后 
【 例 16.23】 将 数据 表 tb_deptl 中 的 columnl 字段 插入 到 location 字段 后 面 ，SQL 语句 如 下 : 
ALTER TABLE tb deptl MODIFY columnl1 VARCHAR(12) AFTER location; 
使 用 DESC 查看 表 tb_deptl ， 结 果 如 下 : 
mysql> DESC tb deptl; 
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二 一 一 一 一 一 一 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 -一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 + 
| Field | Type | Null | Key | Default | Extra | 

+ 一 一 一 一 一 一 一 一 一 一 一 一 一 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 +-------- 十 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 
| id | int(11) | NO | PRI | NULL 1 1 

| name | varchar(30) | YES 1 | NULL | 1 

| column3 | int(11) 1 YES | | NULL | 1 

| location | varchar(60) | YES | | NULL | | 

| column1l | varchar (12) | NO | | NULL | 1 

| managerId | int(10) | YES 1 | NULL | | 

+-------------- +-------------- +------ 一 -一 一 + 一 一 一 一 一 一 一 +------------- +-------- 十 


6 rows in set (0.03 sec) 
可 以 看 到 ，tb_deptl 表 中 的 字段 columnl 已 经 被 移 至 location 字段 之 后 。 


16.3.7 更改 表 的 存储 引擎 


通过 前 面 章节 的 学 习 , 知道 存储 引擎 是 MySQL 中 的 数据 存储 在 文件 或 者 内 存 中 时 采用 的 不 同 
技术 实现 。 可 以 根据 自己 的 需要 ， 选 择 不 同 的 引擎 ， 甚 至 可 以 为 每 一 张 表 选择 不 同 的 存储 引擎 。 
MySQL 中 主要 存储 引擎 有 : MyISAM、InnoDB、MEMORY (HEAP) 、BDB、FEDERATED 等 。 
可 以 使 用 SHOW ENGINES; 语 名 查看 系统 支持 的 存储 引擎 。 表 16-3 列 出 了 MySQL 所 支持 的 存储 
引擎 。 


表 16-3 ”MySQL 支持 的 存储 引擎 











FEDERATED 
MRG MYISAM 





BLACKHOLE 


MEMORY 
ARCHIVE 
InnoDB 
PERFORMANCE SCHEMA 

更 改 表 的 存储 引擎 的 语法 格式 如 下 : 

ALTER TABLE < 表 名 > ENGINE=< 更 改 后 的 存储 引擎 名 >; 

【 例 16.24】 将 数据 表 tb_deptment3 的 存储 引擎 修改 为 MyISAM。 

在 修改 存储 引擎 之 前 ， 先 使 用 SHOW CREATE TABLE 查看 表 tb_deptment3 当前 的 存储 引擎 ， 
结果 如 下 。 
mysql> SHOW CREATE TABLE tb deptment3 \G 


类 大 大 ] 。 IOW * 大 类 
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Table: tb deptment3 
Create Table: CREATE TABLE ‘tb deptment3° 
“id* int(11) NOT NULL, 
“name ”varchar (22) DEFAULT NULL, 


“location. varchar (50) DEFRULT NULL, 
PRIMARY KEY (`id`)， 

UNIQUE KEY “STH‘ (name ) 

) ENGINE=InnoDB DEFAULT CHARSET=gb2312 
1 row in set (0.00 sec) 


可 以 看 到 ， 表 tb_deptment3 当前 的 存储 引擎 为 ENGINE=InnoDB， 接 下 来 修改 存储 引擎 类 型 ， 
输入 如 下 SQL 语句 并 执行 : 


mysql> ALTER TABLE tb deptment3 ENGINE=MyISAM; 


使 用 SHOW CREATE TABLE 再 次 查看 表 tb_deptment3 的 存储 引擎 ， 发 现 表 tb_dept 的 存储 引 
擎 变 成 了 “MyISAM”， 结 果 如 下 : 


mysql> SHOW CREATE TABLE tb deptment3 \G 
AT row 奖 六 六 
Table: tb deptment3 
Create Table: CREATE TABLE ‘tb deptment3 
‘id int(11) NOT NULL, 
“name ”varchar (22) DEFAULT NULL, 


“location’ varchar (50) DEFRULT NULL, 
PRIMARY KEY (`id`)， 
UNIQUE KEY ‘STH 


( 


(“name’) 
) ENGINE=MyISAM DEFAULT CHARSET=gb2312 
1 row in set (0.00 sec) 


16.3.8 ”删除 表 的 外 键 约束 


对 于 数据 库 中 定义 的 外 键 ， 如 果 不 再 需要 ， 可 以 将 其 删除 。 外 键 一 旦 删除 ， 就 会 解除 主 表 和 
从 表 间 的 关联 关系 ，MySQL 中 删除 外 键 的 语法 格式 如 下 : 


ALTER TABLE < 表 名 > DROP FOREIGN KEY < 外 键 约束 名 > 


“外 键 约束 名 ” 指 在 定义 表 时 CONSTRAINT 关键 字 后 面 的 参数 ,详细 内 容 可 参考 16.1.3 节 的 
“使 用 外 键 约束 ”。 


【 例 16.25】 删 除数 据 表 tb_emp9 中 的 外 键 约束 。 
首先 创建 表 tb_emp9， 创 建 外 键 dept[d 关联 tb_deptl 表 的 主键 id，SQL 语句 如 下 : 


CREATE TABLE tb_emp9 


INT(11) PRIMARY KEY, 
name VARCHAR(25), 
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deptId INT(11), 

salary FLOAT, 

CONSTRAINT fk emp dept FOREIGN KEY (deptId) REFERENCES tb deptl (id) 
a 


使 用 SHOW CREATE TABLE 查看 表 tb_emp9 的 结构 ， 结 果 如 下 : 


mysql> SHOW CREATE TABLE tb emp9 \G 
wk 1]。 TOW ** 
Table: tb emp9 
Create Table: CREATE TABLE ‘tb emp9. ( 
“id* int(11) NOT NULL, 
“name. varchar(25) DEFAULT NULL, 
‘deptId. int(11) DEFAULT NULL, 
“salary. float DEFAULT NULL, 
PRIMARY KEY (‘id), 
KEY ‘fk emp dept. (“deptId’), 
CONSTRAINT ‘fk emp_ dept’ FOREIGN KEY ( `deptId `) REFERENCES ‘tb deptl1. (“id'’) 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 
1 row in set (0.00 sec) 


可 以 看 到 ， 已 经 成 功 添加 了 表 的 外 键 ， 下 面 删除 外 键 约 束 ，SQL 语句 如 下 : 
ALTER TABLE tb_emp9 DROP FOREIGN KEY fk emp dept; 


执行 完毕 之 后 ， 将 删除 表 tb_emp9 的 外 键 约束 ， 使 用 SHOW CREATE TABLE 再 次 查看 表 
tb_emp9 结构 ， 结 果 如 下 : 


mysql> SHOW CREATE TABLE tb _emp9 \G 
次 交 类 本 IOW 大 炎炎 
Table: tb_emp9 
Create Table: CREATE TABLE “tb_emp9`” ( 
‘id int(11) NOT NULL, 
‘name. varchar(25) DEFAULT NULL, 
“deptId. int(11) DEFAULT NULL, 
“salary. float DEFAULT NULL, 
PRIMARY KEY ( `id'`)， 
KEY ‘fk emp dept* (‘deptId’) 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 
1 row in set (0.00 sec) 


可 以 看 到 ，tb_emp9 中 已 经 不 存在 FOREIGN KEY， 原 有 的 名 称 为 化 emp_dept 的 外 键 约束 删 
除 成 功 。 


16.4 ”删除 数据 表 


删除 数据 表 就 是 将 数据 库 中 已 经 存在 的 表 从 数据 库 中 删除 。 注 意 ， 在 删除 表 的 同时 ， 表 的 定 
义 和 表 中 所 有 的 数据 均 会 被 删除 。 因 此 ， 在 进行 删除 操作 前 ， 最 好 对 表 中 的 数据 做 个 备份 ， 以 免 造 
成 无 法 挽回 的 后 果 。 本 节 将 详细 讲解 数据 库 表 的 删除 方法 。 
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16.4.1 删除 没有 被 关联 的 表 

在 MySQL 中 ， 使 用 DROP TABLE 可 以 一 次 删除 一 个 或 多 个 没有 被 其 他 表 关 联 的 数据 表 。 语 
法 格式 如 下 : 

DROP TABLE [IF EXISTS] 表 1， 表 2,… 表 ny; 

其 中 “ 表 n” 指 要 删除 的 表 的 名 称 ， 后 面 可 以 同时 删除 多 个 表 ， 只 需 将 要 删除 的 表 名 依次 写 在 
后 面 ， 相 互 之 间 用 去 号 隔 开 即 可 。 如 果 要 删除 的 数据 表 不 存在 ， 则 MySQL 会 提示 一 条 错误 信息 ， 
“ERROR 1051 (42S02): Unknown table ' 表 名 '”。 参 数 “IF EXISTS” 用 于 在 删除 前 判断 删除 的 表 是 
和 否 存 在 ， 加 上 该 参数 后 ， 再 删除 表 的 时 候 ， 如 果 表 不 存在 ，SQL 语句 可 以 顺利 执行 ， 但 是 会 发 出 

告 (warning) 。 

在 前 面 的 例子 中 ， 已 经 创建 了 名 为 tb_dept2 的 数据 表 。 如 果 没 有 ， 读 者 可 输入 语句 ， 创 建 该 
表 ，SQL 语句 如 例 16.7 所 示 。 下 面 使 用 删除 语句 将 该 表 删除 。 

【 例 16.26】 删 除数 据 表 tb_dept2，SQL 语句 如 下 : 

DROP TABLE IF EXISTS tb _dept2; 


语句 执行 完毕 之 后 ， 使 用 SHOW TABLES 命令 查看 当前 数据 库 中 所 有 的 表 ，SQL 语句 如 下 : 
mysql> SHOW TABLES; 





| tb_dept 1 
| tb_deptment3 | 


执行 结果 可 以 看 到 ， 数 据 表 列表 中 已 经 不 存在 名 称 为 tb_dept2 的 表 ， 删 除 操作 成 功 。 
16.4.2 ”删除 被 其 他 表 关 联 的 主 表 


数据 表 之 间 存 在 外 键 关 联 的 情况 下 ， 如 果 直 接 删 除 父 表 ， 结 果 会 显示 失败 。 原 因 是 直接 删除 ， 
将 破坏 表 的 参照 完整 性 。 如 果 必 须要 删除 ， 可 以 先 删除 与 它 关 联 的 子 表 ， 再 删除 父 表 ， 只 是 这 样 同 
时 删除 了 两 个 表 中 的 数据 。 但 有 的 情况 下 可 能 要 保留 子 表 ， 这 时 如 要 单独 删除 父 表 ， 只 需 将 关联 的 
表 的 外 键 约束 条 件 取 消 ， 然 后 就 可 以 删除 父 表 ， 下 面 讲 解 这 种 方法 。 

在 数据 库 中 创建 两 个 关联 表 ， 首 先 ， 创 建 表 tb_dept2，SQL 语句 如 下 : 

CREATE TABLE tb_dept2 

生 INT (11) PRIMARY KEY, 

name VARCHAR (22) ， 

location VARCHAR(50) 

De 


接 下 来 创建 表 tb_emp，SQL 语句 如 下 : 


CREATE TABLE tb_ emp 

1 

id INT (11) PRIMARY KEY, 
name VARCHAR (25) ， 
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deptId INT(11), 
salary FLOAT, 


CONSTRAINT fk emp dept FOREIGN KEY (deptId) REFERENCES tb dept2(id) 
) 7 


使 用 SHOW CREATE TABLE 命令 查看 表 tb_emp 的 外 键 约束 ， 结 果 如 下 : 


mysql> SHOW CREATE TABLE tb emp\G 
大 炎炎 1]。 TOW ** 太 
Table: tb _ emp 
Create Table: CREATE TABLE ‘tb emp. ( 
id. int(11) NOT NULL, 
‘name. varchar (25) DEFAULT NULL, 
‘deptId. int(11) DEFAULT NULL, 
“salary. float DEFAULT NULL, 
PRIMARY KEY (“id’), 
KEY ‘fk emp dept. (“deptId’), 
CONSTRAINT ‘fk emp dept’ FOREIGN KEY ( `deptId ` ) REFERENCES ‘tb dept2. (“id’) 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 
1 row in set (0.00 sec) 


可 以 看 到 ， 以 上 执行 结果 创建 了 两 个 关联 表 tb_dept2 和 表 tb_emp， 其 中 tb_emp 表 为 子 表 , 具 
有 名 称 为 化 emp_dept 的 外 键 约束 ，tb_dept2 为 父 表 ， 其 主键 id 被 子 表 tb_emp 所 关联 。 

【 例 16.27】 删 除 被 数据 表 tb_emp 关联 的 数据 表 tb_dept2。 

首先 直接 删除 父 表 tb_dept2， 输 入 删除 语句 如 下 : 


mysql> DROP TABLE tb dept2; 


ERROR 1217 (23000): Cannot delete or update a parent row: a foreign key constraint 
fails 


可 以 看 到 ， 如 前 所 述 ， 在 存在 外 键 约束 时 ， 主 表 不 能 被 直接 删除 。 
接 下 来 ， 解 除 关 联 子 表 tb_emp 的 外 键 约束 ，SQL 语句 如 下 : 
ALTER TABLE tb_emp DROP FOREIGN KEY fk emp dept; 





语句 成 功 执行 后 , 将 取消 表 tb_emp 和 表 tb_dept2 之 间 的 关联 关系 ,此 时 , 可 以 输入 删除 语句 ， 
将 原来 的 父 表 tb_dept2 删除 ，SQL 语句 如 下 : 

DROP TABLE tb dept2; 

最 后 通过 SHOW TABLES; 查 看 数据 表 列 表 ， 如 下 所 示 : 

mysql> show tables; 


+--------------------- 十 
| Tables_in test db | 
+--------------------- + 
| tb dept | 

| tb_deptment3 1 

… 省 略 部 分 内 容 


可 以 看 到 ， 数 据 表 列 表 中 已 经 不 存在 名 称 为 tb_dept2 的 表 。 
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16.5 ”实战 演练 一 一 数据 表 的 基本 操作 


本 章 全 面 介绍 了 MySQL 中 数据 表 的 各 种 操作 ， 如 创建 表 、 添 加 各 类 约束 、 查 看 表 结 构 ， 以 及 
修改 和 删除 表 。 读 者 应 该 掌握 这 些 基 本 的 操作 ,为 以 后 的 学 习 打下 坚实 的 基础 。 在 这 里 , 给 出 一 
综合 案例 , 让 读者 全 面 回顾 一 下 本 章 的 知识 要 点 , 并 通过 这 些 操作 来 检验 自己 是 否 已 经 掌握 了 数据 
表 的 常用 操作 。 


1. 案例 目的 

创建 、 修 改 和 删除 表 ， 掌 握 数据 表 的 基本 操作 。 

创建 数据 库 company, 按照 表 16-4 和 表 16-5 给 出 的 表 结构 在 company 数据 库 中 创建 两 个 数据 
表 offices 和 employees， 按 照 操作 过 程 完成 对 数据 表 的 基本 操作 。 

表 16-4 ”offices 表 结构 
字段 名 数据 类 型 主键 外 键 | 二 唯一 自 增 

[omieecode |mray | 是 | 百 | 是 | 是 | 百 | 
EE CT FE re rn rs 

















字段 名 数据 类 型 


employeeNumber | INTUD ER | | 


firstName VARCHAR(50) 3 
mobile vapctncs |# | | 
officeCode INT(10) 


bi DATETIME Em Cr 
[sx [varcaars) | | 


VARCHAR(5) 














2. 案例 操作 过 程 
登录 MySQL 数据 库 。 
打开 windows 命令 行 ， 输 入 登录 用 户 名 和 密码 ; 


C:\>mysql -h localhost -u root -p 
了 Enter password: ** 


或 者 打开 MySQL 5.7 Command Line Client， 只 用 输入 用 户 密码 也 可 以 登录 。 登 录 成 功 后 显示 
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如 下 信息 : 


Welcome to the MySQL monitor. Commands end with ; or \g. 
Your MySQL connection id is 2 
Server version: 5.7.10 MySQL Community Server (GPL) 


Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved. 


Oracle is a registered trademark of Oracle Corporation and/or its 
affiliates. Other names may be trademarks of their respective 
Owners. 


Type 'help;' or '\h' for help. Type '\c' to clear the current input statement . 


mysql> 

登录 成 功 ， 可 以 输入 SQL 语句 进行 操作 。 

贺 创建 数据 库 company。 

创建 数据 库 company 的 语句 如 下 : 

mysql> CREATE DATABASE company; 

Query OK, 1 row affected (0.00 sec) 

结果 显示 创建 成 功 ， 在 company 数据 库 中 创建 表 ， 必 须 先 选择 该 数据 库 ， 输 入 语句 如 下 : 


mysql> USE company; 
Database changed 


结果 显示 选择 数据 库 成 功 。 
加 创建 表 offices. 
创建 表 offices 的 语句 如 下 : 


CREATE TABLE offices 

( 

officeCode INT(10) NOT NULL UNIQUE, 
city VARCHAR(50) NOT NULL, 
address VARCHAR(50) NOT NULL, 
country VARCHAR(50) NOT NULL, 
postalCode VARCHAR(15) NOT NULL, 
PRIMARY KEY (officeCode) 

); 


执行 成 功 之 后 ， 使 用 SHOW TABLES; 语 句 查看 数据 库 中 的 表 ， 语 句 如 下 : 


mysql> show tables; 
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| Tables in company | 


1 row in set (0.00 sec) 

可 以 看 到 ， 数 据 库 中 已 经 有 了 数据 表 offices， 创 建成 功 。 
加 创建 表 employees。 

创建 表 employees 的 语句 如 下 : 

CREATE TABLE employees 


( 
employeeNumber INT(11) NOT NULL PRIMARY KEY AUTO_ INCREMENT, 





lastName VARCHAR (50) NOT NULL, 
firstName VARCHAR(50) NOT NULL, 
mobile VARCHAR (25) NOT NULL, 
officeCode INT(10) NOT NULL, 
jobTitle VARCHAR (50) NOT NULL, 
birth DATETIME, 

note VARCHAR (255), 

sex VARCHAR (5)， 


CONSTRAINT office fk FOREIGN KEY (officeCode) REFERENCES offices (officeCode) 
); 


执行 成 功 之 后 ， 使 用 SHOW TABLES; 语 句 查 看 数据 库 中 的 表 ， 语 句 如 下 : 
mysql> show tables; 


+------------------------ 十 
| Tables_in_company | 
+------------------------ 十 
| employees | 

| offices 1 
+------------------------ 十 


2 rows in set (0.00 sec) 
可 以 看 到 ， 现 在 数据 库 中 已 经 创建 好 了 employees 和 offices 两 个 数据 表 。 要 检查 表 的 结构 是 
和 否 按照 要 求 创建 ， 可 使 用 DESC 分 别 查看 两 个 表 的 结构 ， 如 果 语 句 正确 ， 则 显示 结果 如 下 : 


mysql>DESC offices; 


+ 一 一- 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 +------ +-- 一 -一 一 一- 一 全 一 一 一 一 
| Field | Type | Null | Key | Default | Extra | 

+ 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 -一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 +-- 一 一 一 + 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 + 
| officeCode | int(10) | NO | PRI | NULL | | 

I eity | varchar (50) | NO | | NULL | | 

| address | varchar (50) | NO | | NULL | 1 

| country | varchar (50) | NO | | NULL | || 

| postalCode | varchar (15) | NO | | NULL | 1 
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二 一 一 一 一 一 一 一 一 一 一 一 一 二- 一 一 一 一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 + 一 一 一 一 二 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 
5 rows in set (0.02 sec) 


mysql>DESC employees; 











Field | Type | Null | Key | Default | Extra | 
employeeNumber | int(11) | NO | PRI | NULL | auto increment | 
lastName | varchar(50) | NO | | NULL | | 
firstName | varchar (50) | NO | | NULL | | 
mobile | varchar (25) | NO | | NULL | | 
officeCode | int(10) |NO | MUL | NULL | | 
jobTitle | varchar(50) | NO | | NULL | | 
birth | datetime 1 YES 1 | NULL | | 

note | varchar (255) | YES | | NULL | | 

sex | varchar (5) 1 YES | | NULL | | 

+-------------------- +---------------- + 一 一 一 一 一 一 一 + 一 -一 一 一 一 + 一 一 一 一 一 一 一 一 +--------- 
----------- + 


9 rows in set (0.00 sec) 

可 以 看 到 ， 两 个 表 中 字段 分 别 满足 表 16-2 和 表 16-3 中 要 求 的 数据 类 型 和 约束 类 型 。 
加 将 表 employees 的 mobile 字段 修改 到 officeCode 字段 后 面 。 

修改 字段 位 置 ， 需 要 用 到 ALTER TABLE 语句 ， 输 入 语句 如 下 : 


mysql> ALTER TABLE employees MODIFY mobile VARCHAR(25) AFTER officeCode; 
Query OK, 0 rows affected (0.00 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


结果 显示 执行 成 功 ， 使 用 DESC 查看 修改 后 的 结果 如 下 : 


mysql>DESC employees; 





+ 一- 一- 一- 一 二- 一- 一- 一 一 一 一 一 一 一 一 一 +-- 一 一 一 一 一 一 + 一 一 一 一 一 一 +-- 一 一- 一 一- 一 We + 
Field | Type | Null | Key | Default | Extra 1 
+---------- +-------------- + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 + 一 一 一 一 一 一 一 一 +--------------- + 
employeeNumber | int(11) | NO | PRI | NULL | auto increment | 

lastName | varchar(50) | NO | | NULL | 1 
firstName | varchar(50) | NO | | NULL | | 
officeCode | int(10) |NO | MUL | NULL | | 
mobile | varchar(25) | NO | | NULL | | 
jobTitle | varchar(50) | NO | | NULL | | 
employee _birth | datetime 1 YES | | NULL | 1 

note | varchar (255) | YES | | NULL | | 

sex | varchar(5) | YES | | NULL | 1 

+------- 一 二- 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 +- 一 一- 一- 一- 一 一 一 一 一 一 一 + 
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9 rows in set (0.00 sec) 

可 以 看 到 ，mobile 字段 已 经 插入 到 officeCode 字段 的 后 面 。 
四 将 表 employees 的 birth 字段 改名 为 employee_birth。 
修改 字段 名 ， 需 要 用 到 ALTER TABLE 语句 ， 输 入 语句 如 下 : 


ALTER TABLE employees CHANGE birth employee birth DRTETIME 
Query OK, 0 rows affected (0.02 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


结果 显示 执行 成 功 ， 使 用 DESC 查看 修改 后 的 结果 如 下 : 


mysql>DESC employees; 


+---------------------- +--------------: + 一 一 一 一 一 一 一 + 一 一 一 一 一 一 + 一 一 一 一 -一 一 一 +--------- 
----------- + 

| Field | Type | Null | Key | Default | Extra | 

+-------------- +-------------- +-------- +------ 一 + 一 一 一 一 一 一 一 一 +--------------- 十 

| employeeNumber | int(11) | NO | PRI | NULL | auto increment | 

| lastName | varchar(50) | NO | | NULL | | 

| firstName | varchar(50) | NO | | NULL | | 

| mobile | varchar (25) | NO | | NULL | | 

| officeCode | int(10) 1|NO | MUL | NULL | | 

| jobTitle | varchar(50) | NO | | NULL | | 

| employee birth | datetime | YES | | NULL | | 

| note | varchar (255) | YES | | NULL | | 

| sex | varchar (5) | YES | | NULL | | 

+------------- 十 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 +--------- +-------------- 十 


9 rows in set (0.00 sec) 

可 以 看 到 ， 表 中 只 有 employee_birth 字段 ， 已 经 没有 名 称 为 birth 的 字段 了 ， 修 改名 称 成 功 。 
修改 sex 字段 ， 数 据 类 型 为 CHAR(1)， 非 空 约束 。 

修改 字段 数据 类 型 ， 需 要 用 到 ALTER TABLE 语句 ， 输 入 语句 如 下 : 


mysql>ALTER TABLE employees MODIFY sex CHAR(1) NOT NULL; 
Query OK, 0 rows affected (0.00 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


结果 显示 执行 成 功 ， 使 用 DESC 查看 修改 后 的 结果 如 下 : 


mysql>DESC employees; 


+-------------- +-------------- +-------- +------ 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 + 
| Field 1 Type | Null | Key | Default | Extra | 

+ 一 一 一 一 一 一 一 一 一 一 一 一 一 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 +- 一 一 一 -一 一 一 +------ 一 + 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 
| employeeNumber | int(11) | NO | PRI | NULL | auto increment | 

| lastName | varchar(50) | NO | | NULL | | 

| firstName | varchar(50) | NO | | NULL | | 
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| mobile | varchar(25) | NO | | NULL | 1 

| officeCode | int(10) | NO | MUL | NULL | 1 

| jobTitle | varchar(50) | NO | | NULL | 1 

| employee birth | datetime Pyes 1 | NULL | 1 

| note | varchar (255) | YES | | NULL | 1 

| sex | char(1) NE | NULL | 1 

+ 一 一 一 一 一 一 一 一 一 一 一 +---------------- +-------- +—- 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 十 


9 rows in set (0.00 sec) 


执行 结果 可 以 看 到 ，sex 字段 的 数据 类 型 由 前 面 的 VARCHAR(S) 修 改 为 CHAR(1)， 且 其 Null 
列 显示 为 NO， 表 示 该 列 不 允许 空 值 ， 修 改 成 功 。 


加 删除 字段 note。 
删除 字段 ， 需 要 用 到 ALTER TABLE 语句 ， 输 入 语句 如 下 : 


mysql> ALTER TABLE employees DROP note; 
Query OK, 0 rows affected (0.01 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


结果 显示 执行 语句 成 功 ， 使 用 DESC employees; 查 看 语句 执行 后 的 结 


mysql> desc employees; 





+-------------- +-------------- +-------- +---- 一 -一 +-- 一 一 一 一 一 一 一 -一 一 一 一 一 一 一 一 一 一 一 下 
Field | Type | Null | Key | Default | Extra 1 
+-------------- +-------------- +-------- +------ 一 + 一 一 一 一 一 一 一 +------------ + 

employeeNumber | int(11) | NO | PRI | NULL | auto increment | 

| lastName | varchar(50) | NO | | NULL | | 

| firstName | varchar (50) | NO | | NULL | | 

| mobile | varchar(25) | NO | | NULL | 1 
officeCode | int (10) |NO | MUL | NULL | 1 
jobTitle | varchar(50) | NO | | NULL | | 

| employee birth | datetime 1 YES | | NULL | | 
Sex | char(1) | NO | | NULL | 

+------------ +---------------- +-------- + 一 一 一 一 一 + 一 一 一 一 一 一 一 一 +------------ + 


8 rows in set (0.00 sec) 

可 以 看 到 ，DESC 语句 返回 了 8 个 列 字段 ，note 字段 已 经 不 在 表 结构 中 ， 删 除 字段 成 功 。 
加 增加 字段 名 favoriate activity， 数 据 类 型 为 VARCHAR(100)。 

增加 字段 ， 需 要 用 到 ALTER TABLE 语句 ， 输 入 语句 如 下 : 


mysql> ALTER TABLE employees ADD favoriate activity VARCHAR(100); 
Query OK, 0 rows affected (0.01 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


结果 显示 执行 语句 成 功 ， 使 用 DESC employees; 查 看 语句 执行 后 的 结果 : 


mysql> desc employees; 
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+ ==-—=— 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 4- 一 -一 一 -= 一 一 一 一 十 = 一 一 一 一 一 一 一 一 十 = 一 一 一 一 -一 一 一 一 一 一 + 
| Field | Type | Null | Key | Default | Extra 

二 -一 一 一 一 一 一 一 一 一 一 一 一 一 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 +-------- +------ 一 + 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 
lemployeeNumber | int(11) | NO | PRI | NULL | auto increment | 

| lastName | varchar(50) | NO | | NULL | 1 

| firstName | varchar(50) | NO | | NULL | 1 

| mobile | varchar(25) | NO | | NULL | 1 

| officeCode | int (10) lINO | MUL | NULL | 1 

| jobTitle | varchar(50) | NO | | NULL | 1 

| employee birth | datetime 1 YES | | NULL | | 

| sex | char (1) | NO | | NULL | | 

| favoriate activity | varchar(100) | YES | | NULL | | 
+-------------- +-----------------: + 一 一 一 一 一 一 +------- + 一 一 一 一 一 一 一 一 一 +------------ 十 


9 rows in set (0.00 sec) 

可 以 看 到 ， 数 据 表 employees 中 增加 了 一 个 新 的 列 favoriate_activity， 数 据 类 型 为 
VARCHAR(100)， 允 许 空 值 ， 添 加 新 字段 成 功 。 

删除 表 offices。 

在 创建 表 employees 时 , 设置 了 表 的 外 键 , 该 表 关 联 了 其 父 表 的 officeCode 主键 。 如 前 面 所 述 ， 
删除 关联 表 时 ， 要 先 删 除 子 表 employees 的 外 键 约束 , 才能 删除 父 表 。 因此， 必须 先 删除 employees 
表 的 外 键 约束 。 

(1) 删除 employees 表 的 外 键 约束 ， 输 入 如 下 语句 : 


mysql>ALTER TABLE employees DROP FOREIGN KEY office fk; 
Query OK, 0 rows affected (0.01 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


其 中 office 全 为 employees 表 的 外 键 约束 的 名 称 ， 即 创建 外 键 约束 时 CONSTRAINT 关键 字 
后 面 的 参数 ， 结 果 显 示 语 句 执行 成 功 ， 现 在 可 以 删除 ofices 父 表 。 


(2) 删除 表 offices， 输 入 如 下 语句 : 


mysql>DROP TABLE offices; 
Query OK, 0 rows affected (0.00 sec) 


结果 显示 执行 删除 操作 成 功 ， 使 用 SHOW TABLES; 语 句 查看 数据 库 中 的 表 ， 结 果 如 下 : 
mysql> show tables; 


1 row in set (0.00 sec) 


可 以 看 到 ， 数 据 库 中 已 经 没有 名 称 为 offices 的 表 了 ， 删 除 表 成 功 。 
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修改 表 employees 存储 引擎 为 MyISAM. 
修改 表 存 储 引擎 ， 需 要 用 到 ALTER TABLE 语句 ， 输 入 语句 如 下 : 


mysql>ALTER TABLE employees ENGINE=MyISAM; 
Query OK, 0 rows affected (0.01 sec) 
Records: 0 Duplicates: 0 Warnings: 0 


结果 显示 执行 修改 存储 引擎 操作 成 功 ， 使 用 SHOW CREATE TABLE 语句 查看 表 结 构 ， 结 果 
如 下 : 
mysql> show CREATE TABLE employees\G 
ww 太 ]。 IOW ** 太 
Table: employees 
Create Table: CREATE TABLE ‘employees. ( 
‘employeeNumber int(11) NOT NULL AUTO_ INCREMENT, 
“lastName. varchar (50) NOT NULL, 
“firstName ”Varchar(50) NOT NULL, 
“officeCode. int(10) NOT NULL, 
“mobile” varchar (25) DEFAULT NULL, 
“jobTit1le” varchar (50) NOT NULL, 
“employee_birth” datetime DEFRAULT NULL, 
“sex” char (1) NOT NULL, 
‘favoriate _activity”varchar(100) DEFAULT NULL, 
PRIMARY KEY (‘employeeNumber )， 
KEY ‘office fk (‘officeCode') 
) ENGINE=MyISAM DEFAULT CHARSET=utf8 
1 row in set (0.00 sec) 


可 以 看 到 ， 倒 数 第 2 行 中 的 ENGINE 后 面 的 参数 已 经 修改 为 MyISAM， 修 改 成 功 。 
将 表 employees 名 称 修改 为 employees_info。 
修改 数据 表 名 ， 需 要 用 到 ALTER TABLE 语句 ， 输 入 语句 如 下 : 


mysql>ALTER TABLE employees RENAME employees info; 
Query OK, 0 rows affected (0.00 sec) 


结果 显示 执行 语句 成 功 ， 使 用 SHOW TABLES; 语 句 查 看 执行 结 
mysql> show tables; 


1 rows in set (0.00 sec) 


可 以 看 到 数据 库 中 已 经 没有 名 称 为 employees 的 数据 表 。 
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16.6 ”高 手 私房 菜 


技巧 1: 表 删 除 操作 须 谨慎 。 

表 删 除 操作 将 把 表 的 定义 和 表 中 的 数据 一 起 删除 ,并且 MySQL 在 执行 删除 操作 时 ,不 会 有 任 
何 的 确认 信息 提示 ， 因 此 执行 删除 操 时 ， 应 当 慎 重 。 在 删除 表 前 ， 最 好 对 表 中 的 数据 进行 备份 ， 这 
样 当 操作 失误 时 ， 可 以 对 数据 进行 恢复 ， 以 免 造 成 无 法 挽回 的 后 果 。 

同样 的 ， 在 使 用 ALTER TABLE 进行 表 的 基本 修改 操作 时 ， 在 执行 操作 过 程 之 前 ， 也 应 该 确 
保 对 数据 进行 完整 的 备份 ,因为 数据 库 的 改变 是 无 法 撤销 的 ， 如 果 添加 了 一 个 不 需要 的 字段 ， 可 以 
将 其 删除 ， 相 同 的 ， 如 果 删 除了 一 个 需要 的 列 ， 该 列 下 面 的 所 有 数据 都 将 会 丢失 。 


技巧 2: 每 一 个 表 中 都 要 有 一 个 主键 吗 ? 


并 不 是 每 一 个 表 中 都 需要 主键 ， 一 般 的 ， 如 果 多 个 表 之 间 进 行 连接 操作 时 ， 需 要 用 到 主键 。 
因此 并 不 需要 为 每 个 表 建立 主键 ， 而 且 有 些 情 况 最 好 不 使 用 主键 。 

技巧 3: 并 不 是 每 个 表 都 可 以 任意 选择 存储 引擎 。 

外 键 约 束 (FOREIGN KEY) 不 能 跨 引擎 使 用 。MySQL 支持 多 种 存储 引擎 ， 每 一 个 表 都 可 以 
指定 一 个 不 同 的 存储 引擎 ,但 是 要 注意 : 外 键 约束 是 用 来 保证 数据 的 参照 完整 性 ， 如 果 表 之 间 需 要 
关联 外 键 ， 却 指定 了 不 同 的 存储 引擎 ， 这 些 表 之 间 是 不 能 创建 外 键 约束 的 。 所 以 说 ， 存 储 引擎 的 选 
择 也 不 完全 是 随意 的 。 

技巧 4: 带 AUTO_INCREMENT 约束 的 字段 值 是 从 1 开始 的 吗 ? 

默认 的 ， 在 MySQL 中 ，AUTO_INCREMENT 的 初始 值 是 1,， 每 新 增 一 条 记录 ， 字 段 值 自动 加 
1。 设 置 自 增 属性 (AUTO_INCREMENT) 的 时 候 ， 还 可 以 指定 第 一 条 插入 记录 的 自 增 字段 的 值 ， 
这 样 新 插入 的 记录 的 自 增 字 段 值 从 初始 值 开 始 递增 ， 如 在 tb_emp8 中 插入 第 一 条 记录 ， 同 时 指定 
id 值 为 5， 则 以 后 插入 的 记录 的 id 值 就 会 从 6 开始 往 上 增加 。 添 加 唯一 性 的 主键 约束 时 ， 往 往 需 
要 设置 字段 自动 增加 属性 。 








16.7 经 典 习 题 


1. 创建 数据 库 Market， 在 Market 中 创建 数据 表 customers，customers 表 结 构 如 表 16-6 所 示 ， 
按 要 求 进行 操作 。 


表 16-6 ”customers 表 结 构 










cnum INT(11) 

c_name | VARCHAR(S0) 
C_contact VARCHAR(50) 
ccity VARCHAR(50) 


c_birth | DATETIME 
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(1) 创建 数据 库 Market。 

(2) 创建 数据 表 customers， 在 c_num 字段 上 添加 主键 约束 和 自 增 约束 ， 在 c_birth 字段 上 添 
加 非 空 约束 。 

(3) 将 c_contact 字段 插入 到 c_birth 字段 后 面 。 

(4) 将 c_name 字段 数据 类 型 改 为 VARCHAR(70)。 

(5) 将 c_contact 字段 改名 为 c_ phone。 

(6) 增加 c_gender 字段 ， 数 据 类 型 为 CHAR(1)。 

(7) 将 表 名 修改 为 customers_info 。 

(8) 删除 字段 c_city。 

(9) 修改 数据 表 的 存储 引擎 为 MyISAM。 


2. 在 Market 中 创建 数据 表 orders，orders 表 结 构 如 表 16-7 所 示 ， 按 要 求 进行 操作 。 
表 16-7 orders 表 结构 


数据 类 型 主键 


字段 名 外 键 非 空 唯一 自 增 
[omm ma | 是 | | 是 | 是 | 是 | 


[uate |pr | | | | | | 
[es |varcnarso | 二 | 是 | | | | 
(1) 创建 数据 表 orders， 在 o_num 字段 上 添加 主键 约束 和 自 增 约束 ， 在 c_id 字段 上 添加 外 键 
约束 ， 关 联 customers 表 中 的 主键 c num。 
(2) 删除 orders 表 的 外 键 约束 ， 然 后 删除 表 customers。 
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数据 库 管理 系统 的 一 个 最 重要 的 功能 就 是 提供 数据 的 各 种 操作 ， 包 括 插入 数据 、 更 新 数据 、 
删除 数据 和 查询 数据 等 。 其 中 数据 查询 不 是 简单 返回 数据 库 中 存储 的 数据 , 而 是 应 该 根据 需要 对 数 
据 进行 筛选 ， 以 及 数据 将 以 什么 样 的 格式 显示 。MySQL 提供 了 功能 强大 、 灵 活 的 语句 来 实现 这 些 
操作 。 本 章 将 介绍 数据 的 这 些 基 本 操作 方法 和 技巧 。 


























本 章 学 习 目 标 
@ 掌握 如 何 插 入 数据 
@ 掌握 如 何 更 新 数据 
@。 掌握 如 何 删除 数据 
@ 掌握 如 何 查询 数据 
@ 熟练 综合 案例 数据 的 基本 操作 


17.1 插入 数据 


在 使 用 数据 库 之 前 ， 数 据 库 中 必须 要 有 数据 ，MySQL 中 使 用 INSERT 语句 向 数据 表 中 插入 新 
的 数据 记录 。 可 以 插入 的 方式 有 : 插入 完整 的 记录 ,插入 记录 的 一 部 分 ， 插 入 多 条 记录 ， 以 及 插入 
另 一 个 查询 的 结果 。 下 面 将 介绍 这 些 内 容 。 


17.1.1 为 表 的 所 有 字段 插入 数据 


使 用 基本 的 INSERT 语句 插入 数据 要 求 指定 表 的 名 称 和 插入 到 新 记录 中 的 值 。 基 本 语法 格式 
为 : 
INSERT INTO table name (column list) VALUES (value list); 


table_name 指定 要 插入 数据 的 表 名 , column_list 指定 要 插入 数据 的 那些 列 ,value_list 指定 
每 个 列 对 应 插入 的 数据 。 注 意 ， 使 用 该 语句 时 字段 列 和 数据 值 的 数量 必须 相同 。 
本 章 将 使 用 样 例 表 person， 创 建 语句 如 下 : 


CREATE TABLE person 
( 
id INT UNSIGNED NOT NULL AUTO INCREMENT, 
name CHAR(40) NOT NULL DEFAULT '', 
age INT NOT NULL DEFAULT 0, 
info CHAR(50) NULL, 
PRIMARY KEY (id) 
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向 表 中 所 有 字段 插入 值 的 方法 有 两 种 : 一 种 是 指定 所 有 字段 名 ， 另 一 种 是 完全 不 指定 字 段 
名 。 

【 例 17.1】 在 表 person 中 ， 插 入 一 条 新 记录 ，id 值 为 1，name 值 为 Green，age 值 为 21，info 
值 为 lawyer，SQL 语句 如 下 : 

执行 插入 操作 之 前 ， 使 用 SELECT 语句 查看 表 中 的 数据 : 

mysql> SELECT * FROM person; 

Empty set (0.00 sec) 


结果 显示 当前 表 为 空 ， 没 有 数据 ， 接 下 来 执行 插入 操作 : 


mysql> INSERT INTO person (id ,name, age , info) 
-> VALUES (1,'Green', 21, 'Lawyer'); 
Query OK, 1 row affected (0.00 sec) 


语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person; 


+----+-------- 十 -一 -一 +------------ + 
| id | name | age | info || 
+----+-------- 二 -一 -一 +------------ 十 
| 1 1Green | 21 | Lawyer 1 
+----+-------- +--- 一 一 +------------ 十 


可 以 看 到 插入 记录 成 功 。 在 插入 数据 时 ， 指 定 了 表 person 的 所 有 字段 ， 因 此 将 为 每 一 个 字段 
插入 新 的 值 。 

INSERT 语句 后 面 的 列 名 称 顺序 可 以 不 是 表 person 定义 时 的 顺序 。 即 插入 数据 时 ,不 需要 
按照 表 定义 的 顺序 插入 ， 只 要 保证 值 的 顺序 与 列 字段 的 顺序 相同 就 可 以 ， 如 下 面 的 例子 。 

【 例 17.2】 在 表 person 中 ， 插 入 一 条 新 记录 ，id 值 为 2，name 值 为 Suse，age 值 为 22，info 
值 为 dancer，SQL 语句 如 下 : 

mysql> INSERT INTO person (age ,name, id , info) 

=> VALUES ‘(22, "Suvuse', 2; dancerT1) 7 
语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person; 








+ 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 + 一- 一 一 一 一 一 一 一 一 一 + 
id | name | age | info | 
+----+-------- + 一 一 一 一 + 一- 一 一 一 一 一 一 一 一 一 + 
1 | Green | 21 | Lawyer | 
2 1 Suse | 22 | dancer 1 
二 一 一 一 一 + 一 一 一 一 一 一 一 一 二 -一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 
由 结果 可 以 看 到 ，INSERT 语句 成 功 插 入 了 一 条 记录 。 
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使 用 INSERT 插入 数据 时 ， 人 允许 列 名 称 列表 column_list 为 空 ， 此 时 ， 值 列表 中 需要 为 表 的 每 
一 个 字段 指定 值 ， 并 且 值 的 顺序 必须 和 数据 表 中 字段 定义 时 的 顺序 相同 。 


【 例 17.3】 在 表 person 中 ， 插 入 一 条 新 记录 ，SQL 语句 如 下 : 


mysql> INSERT INTO Person 
-> VALUES (3,'Mary', 24, 'Musician') 7 
Query OK, 1 row affected (0.00 sec) 


语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person; 


+----+-------- 十 -一 一 -一 + 一 -一 -一 一 一 一 一 + 
| id | name | age | info | 
+----+-------- +----- +------------ 十 
| 1 | Green | 21 | Lawyer | 
| 2 1 Suse | 22 | dancer | 
[> | 24 | Musician | 
+----+-------- +-- 一 一- +------------ + 


可 以 看 到 插入 记录 成 功 。 数 据 库 中 增加 了 一 条 id 为 3 的 记录 ， 其 他 字段 值 为 指定 的 插入 值 。 
本 例 的 INSERT 语句 中 没有 指定 插入 列表 ， 只 有 一 个 值 列表 。 在 这 种 情况 下 ， 值 列表 为 每 一 个 字段 
列 指定 插入 值 ， 并 且 这 些 值 的 顺序 必须 和 表 person 中 字段 定义 的 顺序 相同 。 


C0 虽然 使 用 INSERT 插入 数据 时 可 以 忽略 插入 数据 的 列 名 称 ， 但 是 如 果 不 包含 列 名 称 ， 
那么 VALUES 关键 字 后 面 的 值 不 仅 要 求 必 须 完整 而 且 顺 序 必须 和 表 定 义 时 列 的 顺序 
相同 。 如 果 表 的 结构 被 修改 ， 则 对 列 进行 增加 、 删 除 或 者 位 置 改变 操作 ， 将 使 得 用 这 
种 方式 插入 数据 时 的 顺序 也 必须 同时 改变 。 如 果 指 定 列 名 称 ， 则 不 会 受到 表 结 构 改变 
的 影响 。 


简 
Sl 


17.1.2 为 表 的 指定 字段 插入 数据 

为 表 的 指定 字段 插入 数据 , 就 是 在 INSERT 语句 中 只 向 部 分 字段 中 插入 值 , 而 其 他 字段 的 
值 为 表 定 义 时 的 默认 值 。 

【 例 17.4】 在 表 person 中 ,插入 一 条 新 记录 ,name 值 为 Willam，age 值 为 20, info 值 为 sports 
man，SQL 语句 如 下 : 














mysql> INSERT INTO person (name, age, info) 
-> VALUES('Willam', 20, 'sports man'); 
Query OK, 1 row affected (0.00 sec) 


提示 信息 表示 插入 一 条 记录 成 功 。 使 用 SELECT 查询 表 中 的 记录 ， 查 询 结果 如 下 : 


mysql> SELECT * FROM person; 
+-- 一 -+ 一 一 -一 一 十 一 一 一 一 一 + 一 一- 一 一 一 一 一 一 一 一 一 + 
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| id | name | age | info 1 
十 =- 一 一 十 ~ 一 一 一 一 一 一 一 十 一 一 一 一 一 十 ~ 一 一 一 一 一 一 一 一 一 一 一 + 
| 1 | Green | 21 | Lawyer | 
1 2 1 Suse | 22 | dancer 1 
| 3 | Mary | 24 | Musician | 
| 4 | Willam | 20 | sports man | 
+----+-------- 十 -一 -一 +----------- 一 + 


可 以 看 到 插入 记录 成 功 。 如 这 里 的 id 字段 ， 查 询 结果 显示 ， 该 字段 自动 添加 了 一 个 整数 
值 4。 在 这 里 id 字段 为 表 的 主键 ， 不 能 为 定 ， 系 统 会 自动 为 该 字段 插入 自 增 的 序列 值 。 在 插 
入 记录 时 ， 如 果 某 些 字段 没有 指定 插入 值 ，MySQL 将 插入 该 字段 定义 时 的 默认 值 。 下 面 例子 








说 明 在 没有 指定 列 字段 时 ， 插 入 默认 值 。 


【 例 17.5】 在 表 person 中 ， 插 入 一 条 新 记录 ，name 值 为 Laura，age 值 为 23，SQL 语句 如 下 : 


mysql> INSERT INTO person (name，age ) VALUES ('Laura', 25); 


Query OK, 1 row affected (0.00 sec) 
语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person; 


+----+-------- 十 -一 一 -一 +------------ 十 
| id | name | age | info | 
+----+-------- 二 ---- 一 +----------- 一 十 
| 1 1 Green | 21 | Lawyer 1 
| 2 1 Suse | 22 | dancer | 
| 3 | Mary | 24 | Musician | 
| 4 | Willam | 20 | sports man | 
WSal Laura 1 25 | NULL 1 
+----+-------- + 一 一 一 一 +- 一 -一 一 一 一- 一 一 一 一 + 


可 以 看 到 ,在 本 例 插入 语句 中 , 没有 指定 info 字段 值 ， 查 询 结果 显示 ，info 字段 在 定义 时 


指定 默认 值 为 NULL， 因 此 系统 自动 为 该 字段 插入 空 值 。 


CY 要 保证 每 个 插入 值 的 类 型 必须 和 对 应 列 的 数据 类 型 匹配 ， 如 果 类 型 不 同 ， 将 无 法 


提示 插入 ， 并 且 MySQL 会 产生 错误 。 


17.1.3 同时 插入 多 条 记录 


INSERT 语句 可 以 同时 向 数据 表 中 插入 多 条 记录 , 插入 时 指定 多 个 值 列表 , 每 个 值 列表 之 间 用 


逗号 分 隔 开 ， 基 本 语法 格式 如 下 : 


INSERT INTO table name (column list) 
VALUES (value list1), (value list2),..., (value listn); 
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“value_list1，value_list2，...value_listn; ”分 别 表示 第 n 个 插入 记录 的 字段 的 值 列表 。 


【 例 17.6】 在 表 person 中 , 在 name、age 和 info 字段 指定 插入 值 ， 同 时 插入 3 条 新 记录 ，SQL 
语句 如 下 : 


INSERT INTO person (name, age, info) 

VALUES ('Evans',27, 'secretary'), 
(pale'r22y "cook')s 
('Edison',28, 'singer'); 


语句 执行 结果 如 下 : 


mysql> INSERT INTO person (name, age, info) 
-> VALUES ('Evans',27, 'secretary'), 
-> ("Dale’y227 "COOok’)y 
-> ('Edison',28, 'singer'); 

Query OK, 3 rows affected (0.00 sec) 

Records: 3 Duplicates: 0 Warnings: 0 


语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person; 





+----+-------- +----- +------------ 十 
id | name | age | info | 
+----+-------- 二 -一 一 一 一 二- 一 一 一 一 一 一 一 一 一 一 + 
1 | Green | 21 | Lawyer | 
2 1 Suse | 22 | dancer 1 
3 | Mary | 24 | Musician | 
4 | Willam | 20 | sports man | 
5 | Laura | 25 | NULL 1 
6 | Evans | 27 | secretary | 
7 | Dale L221 Coo | 
8 | Edison | 28 | singer 1 
+----+-------- + 一 一 一 + 一 一 一 一 一 一 一 一 一 一 一 + 


由 结果 可 以 看 到 ，INSERT 语句 执行 后 ， 表 person 中 添加 了 3 条 记录 ， 其 name 和 age 字段 分 
别 为 指定 的 值 ，id 字段 为 MySQL 添加 的 默认 的 自 增值 。 

使 用 INSERT 同时 插入 多 条 记录 时 ，MySQL 会 返回 一 些 在 执行 单行 插入 时 没有 的 额外 信息 ， 
这 些 包 含 数值 的 字符 串 的 意思 分 别 如 下 。 

@ Records: 表明 插入 的 记录 条 数 。 

@ Duplicates: 表明 插入 时 被 忽略 的 记录 ， 原 因 可 能 是 这 些 记录 包含 了 重复 的 主键 值 。 

@ 。 Warnings: 表明 有 问题 的 数据 值 ， 例 如 发 生 数据 类 型 转换 。 


【 例 17.7】 在 表 person 中 ， 不 指定 插入 列表 ， 同 时 插入 两 条 新 记录 ，SQL 语句 如 下 : 


INSERT INTO person 
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VALUES (9,'Harry',21, 'magician’'), 
(NULL, 'Harriet',19, 'pianist'); 
语句 执行 结果 如 下 : 
mysql> INSERT INTO person 
-> VALUES (9, 'Harry',21, 'magician'), 
-> (NULL,'Harriet',19, 'pianist'); 
Query OK, 2 rows affected (0.01 sec) 
Records: 2 Duplicates: 0 Warnings: 0 


语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person; 





+----+--------- +----- 二 -一 一 一 一 一 一 一 一 一 一 + 
id | name | age | info | 
+----+--------- +-- 一 -一 +------------ + 
1 | Green | 21 | Lawyer | 
2 | Suse | 22 | dancer | 
3 | Mary | 24 | Musician | 
4 | Willam | 20 | sports man | 
5 | Laura | 25 | NULL | 
6 | Evans | 27 | secretary | 
7 | Dale L222 .co0k | 
8 | Edison | 28 | singer 1 
9 | Harry | 21 | magician 1 
10 | Harriet | 19 | pianist | 
+----+--------- + 一 一 一 一 + 一 一 一 一 一- 一 一 一 一 一 + 


由 结果 可 以 看 到 , INSERT 语句 执行 后 , 表 person 中 添加 了 两 条 记录 , 与 前 面 介绍 单个 INSERT 
语法 不 同 ，person 表 名 后 面 没有 指定 插入 字段 列表 ， 因 此 VALUES 关键 字 后 面 的 多 个 值 列 表 都 要 
为 每 一 条 记录 的 每 一 个 字段 列 指定 插入 值 ， 并 且 这 些 值 的 顺序 必须 和 表 person 中 字段 定义 的 顺序 
相同 ， 带 有 AUTO_INCREMENT 属性 的 id 字段 插入 NULL 值 ， 系 统 会 自动 为 该 字段 插入 唯一 的 
自 增 编号 。 


C9 一 个 同时 插入 多 行 记录 的 INSERT 语句 可 以 等 同 于 多 个 单行 插入 的 INSERT 语 句 ， 


但 是 同时 插入 多 行 的 INSERT 语句 在 处 理 过 程 中 效率 更 高 。 所 以 在 插入 多 条 记录 
提 示 。 时 , 最 好 选择 使 用 单条 INSERT 语句 的 方式 插入 。 


17.2 ”更 新 数据 


表 中 有 数据 之 后 ， 接 下 来 可 以 对 数据 进行 更 新 操作 ，MySQL 中 使 用 UPDATE 语句 更 新 表 中 
的 记录 ， 可 以 更 新 特定 的 行 或 者 同时 更 新 所 有 的 行 。 基 本 语法 结构 如 下 : 
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UPDATE table name 
SET column namel = valuel,column name2=value2,..., column namen=valuen 
WHERE (condition); 


“column_ namel,column_name2,...,column_namen” 为 指定 更 新 的 字段 的 名 称 ;， “valuel， 
value2,...valuen” 为 相对 应 的 指定 字段 的 更 新 值 ，condition 指定 更 新 的 记录 需要 满足 的 条 件 。 
更 新 多 个 列 时 ， 每 个 “ 列 - 值 ” 对 之 间 用 去 号 隔 开 ， 最 后 一 列 之 后 不 需要 逗号 。 

【 例 17.8】 在 表 person 中 ， 更 新 id 值 为 10 的 记录 ， 将 age 字段 值 改 为 3， 将 name 字段 
值 改 为 LiMing，SQL 语句 如 下 : 

UPDATE person SET age = 15, name= 'LiMing' WHERE id = 10; 


更 新 操作 执行 前 可 以 使 用 SELECT 语句 查看 当前 的 数据 : 


mysql> SELECT * FROM person WHERE id=10; 


+----+------- +----- + 一- 一 一 一 一 一 + 
| id | name | age | info | 
+----+------- +----- +--------- 十 
| 10 | Harry | 20 | student | 
+----+------- +----- + 一- 一 一 一 一 一 一 + 


由 结果 可 以 看 到 更 新 之 前 ，id 等 于 10 的 记录 的 name 字段 值 为 harry，age 字段 值 为 20， 下 面 
使 用 UPDATE 语句 更 新 数据 ， 语 句 执行 结果 如 下 : 

mysql> UPDATE person SET age = 15, name='LiMing' WHERE id = 10; 

Query OK, 1 row affected (0.00 sec) 

Rows matched: 1 Changed: 1 Warnings: 0 


语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM Person WHERE id=10; 


+----+-------- +----- +--------- 十 
| id | name | age | info | 
二 -一 一 一 + 一 一 一 一 一 一 一 一 + 一 -一 一- +--------- 十 
| 10 | LiMing | 15 | student | 
二 -一 一 一 + 一 一 一 一 一 一 一 一 二- 一 一 一 一 + 一 一 -一 一 一 一 一 一 + 


由 结果 可 以 看 到 ，id 等 于 10 的 记录 中 的 name 和 age 字段 的 值 已 经 成 功 被 修改 为 指定 值 。 














@! 保证 UPDATE 以 WHERE 子 句 结束 , 通过 WHERE 子 句 指定 被 更 新 的 记录 所 需要 
满足 的 条 件 ， 如 果 忽略 WHERE 子 句 ，MySQL 将 更 新 表 中 所 有 的 行 。 
J \ 
【 例 17.9】 在 表 person 中 ， 更 新 age 值 为 19 到 22 的 记录 ， 将 info 字段 值 都 改 为 student， 
SQL 语句 如 下 : 
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UPDATE Person SET info= 'student' WHERE id BETWEEN 19 RND 22; 
更 新 操作 执行 前 可 以 使 用 SELECT 语句 查看 当前 的 数据 : 


mysql> SELECT * FROM Person WHERE age BETWEEN 19 RND 22; 


+----+--------- + 一 + 一 -一 一 一 一 一 一 一 + 
| id | name | age | info | 
+----+--------- +---- 一 + 一 一 一 一 -一 一 一 + 
| 1 | willam | 20 | sports man | 
| 3 | Green | 21 | Lawyer 1 
| 4 1 Suse | 22 | dancer 1 
| 6 | Dale 2 Cook | 
| 8 | Harry | 21 | magician 1 
1 9 | Harriet | 19 | pianist | 
+----+--------- +----: +------------ 十 


可 以 看 到 , 这 些 age 字段 值 在 19 到 22 之 间 的 记录 的 info 字段 值 各 不 相同 。 下 面 使 用 UPDATE 
语句 更 新 数据 ， 语 句 执行 结果 如 下 : 
mysql> UPDATE person SET info='student' WHERE age BETWEEN 19 AND 22; 


Query OK, 6 rows affected (0.00 sec) 
Rows matched: 6 Changed: 6 Warnings: 0 


语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person WHERE age BETWEEN 19 AND 22; 


+----+--------- +- 一 一 一 +--------- 十 
| id | name | age | info |] 
+----+--------- +----- + 一 -一 一 一 -一 一 + 
| 1 | willam | 20 | student | 
| 3 | Green | 21 | student | 
| 4 1 Suse | 22 | student | 
| 6 | Dale | 22 | student | 
| 8 | Harry | 21 | student | 
oaarriet I L900 student ll 
二 一 一 一 一 二 一 一 一 一 一 一 一 一 一 +- 一 一 一 一 二 -一 一 一 一 一 一 一 一 + 





结果 可 以 看 到 ，UPDATE 执行 后 ， 成 功 地 将 表 中 符合 条 件 的 记录 的 info 字段 值 都 改 为 


student。 

















17.3 ”删除 数据 


从 数据 表 中 删除 数据 使 用 DELETE 语句 ，DELETE 语句 允许 WHERE 子 句 指定 删除 条 件 。 
DELETE 语句 基本 语法 格式 如 下 : 


DELETE FROM table _ name [WHERE <condition>]; 
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table_name 指定 要 执行 删除 操作 的 表 ; “[WHERE <condition>]” 为 可 选 参数 ， 指 定 删除 
条 件 ， 如 果 没 有 WHERE 子 句 ，DELETE 语句 将 删除 表 中 的 所 有 记录 。 
【 例 17.10】 在 表 person 中 ， 删 除 id 等 于 10 的 记录 ，SQL 语句 如 下 : 
执行 删除 操作 前 使 用 SELECT 语句 查看 当前 id=10 的 记录 : 





mysql> SELECT * FROM Person WHERE id=10; 


+----+-------- +-- 一 一 +---- 一 一 -一 + 
| id | name | age | info 1 
+----+-------- +----- +----- 一 -一 + 
| 10 | LiMing | 15 | student | 
+----+-------- +--- 一 一 +--------- + 


可 以 看 到 ,现在 表 中 有 id=10 的 记录 ， 下 面 使 用 DELETE 语句 删除 记录 ,语句 执行 结果 如 下 : 


mysql> DELETE FROM person WHERE id = 10; 
Query OK, 1 row affected (0.02 sec) 


语句 执行 完毕 ， 查 看 执行 结果 : 

mysql> SELECT * FROM person WHERE id=10; 

Empty set (0.00 sec) 

查询 结果 为 空 ， 说 明 删 除 操作 成 功 。 

【 例 17.11 】 在 person 表 中 , 使 用 DELETE 语句 同时 删除 多 条 记录 , 在 前 面 UPDATE 语句 
中 将 age 字段 值 在 19 到 22 之 间 的 记录 的 info 字段 值 修改 为 student， 在 这 里 删除 这 些 记录 ， 
SQL 语句 如 下 : 

DELETE FROM person WHERE age BETWEEN 19 AND 22; 

执行 删除 操作 前 使 用 SELECT 语句 查看 当前 的 数据 : 


mysql> SELECT * FROM person WHERE age BETWEEN 19 AND 22; 


+ 一 一 一- 二 一 一 一 一 一 一 一 一 一 +----- 二 一 一 一 一 一 一 一 一 一 + 
| id | name | age | info 1 
二 一 一 一 一 二 一 一 一 一 一 一 一 一 一 +- 一 一 -一 + 一 一 一 一 一 一 一 一 + 
| 1 | willam | 20 | student | 
| 3 | Green | 21 | student | 
| 4 1 Suse | 22 | student | 
| 6 | Dale | 22 | student | 
1 8 1 Barrey | 21 | student | 
mo laarriet Lo student ll 


可 以 看 到 ， 这 些 age 字段 值 在 19 到 22 之 间 的 记录 存在 表 中 。 下 面 使 用 DELETE 删除 这 些 记 


mysql> DELETE FROM Person WHERE age BETWEEN 19 RND 22; 
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Query OK, 6 rows affected (0.00 sec) 

语句 执行 完毕 ， 查 看 执行 结果 : 

mysql> SELECT * FROM person WHERE age BETWEEN 19 AND 22; 
Empty set (0.00 sec) 

查询 结果 为 空 ， 删 除 多 条 记录 成 功 。 

【 例 17.12】 删 除 person 表 中 所 有 记录 ，SQL 语句 如 下 : 





DELETE FROM person; 
执行 删除 操作 前 使 用 SELECT 语句 查看 当前 的 数据 : 


mysql> SELECT * FROM person; 


+----+--------- +---- +----- 一 -一 + 
| id | name | age | info |! 
+----+--------- +----- +--------- 一 一 + 
| 2 | Laura 1 25 | NULL 1 
| 5 | Evans | 27 | secretary | 
| 7 | Edison | 28 | singer | 
| 11 | Beckham | 31 | police 1 
+----+--------- +---- +----- 一 -一 一 一 + 


结果 显示 person 表 中 还 有 4 条 记录 ， 执 行 DELETE 语句 删除 这 4 条 记录 : 


mysql> DELETE FROM person; 
Query OK, 4 rows affected (0.00 sec) 


语句 执行 完毕 ， 查 看 执行 结果 : 


mysql> SELECT * FROM person; 
Empty set (0.00 sec) 


查询 结果 为 空 ， 删 除 表 中 所 有 记录 成 功 ， 现 在 person 表 中 已 经 没有 任何 数据 记录 。 





如 果 想 删除 表 中 的 所 有 记录 ，, 还 可 以 使 用 TRUNCATE TABLE 语句 , TRUNCATE 
将 直接 删除 原来 的 表 并 重新 创建 一 个 表 ， 其 语法 结构 为 TRUNCATE TABLE 


提 示 table name。TRUNCATE 直接 删除 表 而 不 是 删除 记录 ， 因 此 执行 速度 比 


DELETE 快 。 


17.4 查询 数据 
MySQL 从 数据 表 中 查询 数据 的 基本 语句 为 SELECT 语句 。SELECT 语句 的 基本 格式 是 : 


SELECT 
{* | < 字段 列表 >} 
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FROM < 表 1>,< 表 2>... 
[WHERE < 表达 式 >] 
[GROUP BY <group by definition>] 
[HAVING <expression> [{<operator> <expression>}...]] 
[ORDER BY <order by definition>] 
[LIMIT [<offset>,] <row count>] 
] 
SELECT [字段 1, 字 段 2,.…, 字 段 n] 
FROM [ 表 或 视图 ] 
WHERE [查询 条 件 ] ; 


@ 人 ft | < 字段 列表 >}: 包含 星 号 通配符 和 字段 列表 。“*” 表 示 查 询 所 有 的 字段 ; “字段 列 
表 ” 表 示 查 询 指定 的 字段 ， 字 段 列表 至 少 包含 一 个 子 段 名 称 ， 如 果 要 查询 多 个 字段 ， 
多 个 字段 之 间 用 喜 号 隔 开 ， 最 后 一 个 字段 后 不 要 加 过 号 。 

@ FROM < 表 1>,< 表 2>.…: 表 1 和 表 2 表 示 查 询 数据 的 来 源 ， 可 以 是 单个 或 者 多 个 。 

WHERE 子 句 : 可 选项 , 如 果 选 择 该 项 , [查询 条 件 ] 将 限定 查询 行 必须 满足 的 查询 条 件 。 

@ GROUP BY < 字段 >: 该 子 句 告诉 MySQL 如 何 显示 查询 出 来 的 数据 ， 并 按照 指定 的 字 
段 分 组 。 

@ [ORDER BY < 字段 >]: 该 子 句 告诉 MySQL 按 什么 样 的 顺序 显示 查询 出 来 的 数据 。 可 
以 进行 的 排序 有 : 升序 (ASC)、 降 序 (DESC )。 


@ [LIMIT [<offset>,] <row count>]: 该 子 句 告诉 MySQL 每 次 显示 查询 出 来 的 数据 条 数 。 
@ SELECT 的 可 选 参数 比较 多 。 读 者 可 能 无 法 一 下 子 完 全 理解 ， 不 要 紧 ， 接 下 来 从 最 简 


单 的 开始 ， 一 步 一 步 深入 学 习 之 后 ， 就 会 对 各 个 参数 的 作用 有 清晰 的 认识 。 
下 面 创建 数据 表 fruits， 该 表 中 包含 了 本 章 中 需要 用 到 的 数据 。 
首先 定义 数据 表 。 
CREATE TABLE fruits 
( 


Ed char (10) NOT NULL, 
SE INT NOT NULL, 
f name char(255) NOT NULL, 


f price decimal(8,2) NOT NULL, 
PRIMARY KEY (f_id) 
EE 


为 了 演示 如 何 使 用 SELECT 语句 ， 需 要 插入 数据 。 请 读者 插入 如 下 数据 : 


mysql> INSERT INTO fruits (f id, s id, f name, f price) 
-> VALUES('al', 101,'apple',5.2), 
-> ('b1",101,'blackberry's 10.2), 
-> (bsl',102,'0range'’, 11.2), 
=> DSS 105r "melonr 2) 


使 用 SELECT 语句 查询 f id 和 f name 字段 的 数据 。 


该 语句 的 执行 过 程 是 ，SELECT 语句 决定 了 要 查询 的 列 值 ， 在 这 里 查询 f id 和 f name 两 
个 字段 的 值 ， FROM 子 句 指定 了 数据 的 来 源 ， 这 里 指定 数据 表 fruits， 因 此 返回 结果 为 fruits 
表 中 f id 和 f_name 这 两 个 字段 下 所 有 的 数据 。 其 显示 顺序 为 添加 到 表 中 的 顺序 。 
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17.4.1 查询 所 有 字段 

1. 在 SELECT 语句 中 使 用 星 号 “*” 通 配 符 查询 所 有 字段 

SELECT 查询 记录 最 简单 的 形式 是 从 一 个 表 中 检索 所 有 记录 ， 实 现 的 方法 是 使 用 星 号 (*) 通 
配 符 指定 查找 所 有 的 列 的 名 称 。 语 法 格式 如 下 : 

SELECT * FROM 表 名 ; 

【 例 17.13】 从 fruits 表 中 检索 所 有 字段 的 数据 ，SQL 语句 如 下 : 


mysql> SELECT * FROM fruits; 


+------ +------ +------------ +--------- 十 
1fid 1 sid | f name | £ price | 
+------ +------ +------------ +--------- + 
Wa | 101 | apple | S20 
| a2 | 103 | apricot | e200 
[es | 101 | blackberry | 10.20 | 
[I :2 | 104 | berry | F600 
| b5 | 107 | xxxx 1 3.60 | 
| bsl | 102 | orange 1 LE 
| bs2 | 105 | melon | e229] 
Jece | 101 | cherry | 3520 1 
| | 104 | lemon | 6.40 | 
| ml | 106 | mango 1 15.60 | 
| m2 | 105 | xbabay | 2a60° | 
| m3 W1037 I -xxtt | 11.60 | 
102 | 103 | coconut | 95200 
| tl | 102 | banana Ia0es30 
| 区 2 | 102 | grape | 5.30 | 
| t4 | 107 | xbababa | 3.60 | 
+------ + 一 -一 一 一 一 十 一 一 一 一 一 一 一 一 一 一 一 一 +--------- 十 


可 以 看 到 ， 使 用 星 号 通配符 时 ， 将 返回 所 有 列 ， 列 按照 定义 表 的 时 候 的 顺序 显示 。 

2. 在 SELECT 语句 中 指定 所 有 字段 

另外 一 种 查询 所 有 字段 值 的 方法 ， 根 据 前 面 SELECT 语句 格式 ，SELECT 关键 字 后 面 字段 名 
为 将 要 查找 的 数据 。 如 果 忘 记 了 字段 名 称 ， 可 以 使 用 DESC 命令 查看 表 的 结构 。 有 时 候 ， 可 能 
中 的 字段 比较 多 ， 不 一 定 能 记得 所 有 字段 的 名 称 ， 因 此 该 方法 有 时 候 很 不 方便 ， 不 建议 使 用 。 例 如 
查询 fruits 表 中 的 所 有 数据 ，SQL 语句 也 可 以 书写 如 下 : 


SELECT f id，s_id ,f name, f price FROM fruits; 


查询 结果 与 例 17.14 相同 。 
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0@! 一 般 情况 下 ， 除 非 需要 使 用 表 中 所 有 的 字段 数据 ， 最 好 不 要 使 用 通配符 “+”， 使 

用 通配符 虽然 可 以 节省 输入 查询 语句 的 时 间 ， 但 是 获取 不 需要 的 列 数据 会 降低 查 

提 示 。 询 的 效率 和 所 使 用 的 应 用 程序 的 效率 。 通 配 符 的 优势 是 ， 当 不 知道 所 需要 的 列 的 
名 称 时 ， 可 以 获取 它们 。 


17.4.2 ”查询 指定 字段 
1. 查询 单个 字段 
查询 表 中 的 某 一 个 字段 ， 语 法 格式 为 : 
SELECT 列 名 FROM 表 名 ; 
【 例 17.14】 查 询 当 前 表 中 f_name 列 所 有 水 果 名 称 ，SQL 语句 如 下 : 
SELECT f name FROM fruits; 


该 语句 使 用 SELECT 声明 从 fruits 表 中 获取 名 称 为 fname 字段 下 的 所 有 水 果 名 称 ， 指 定 字 段 
的 名 称 紧 跟 在 SELECT 关键 字 之 后 ， 查 询 结果 如 下 : 


mysql> SELECT f name FROM fruits; 


| apple | 
| apricot 1 
| blackberry | 
| berry 1 
IE | 
| orange | 
| melon 1 
| cherry 1 
| lemon 1 
| mango | 
| xbabay | 
| xxtt | 
| coconut 1 
| banana 1 
| 

1 





输出 结果 显示 了 fruits 表 中 f_name 字段 下 的 所 有 数据 。 
2. 查询 多 个 字段 


使 用 SELECT 语句 ， 可 以 获取 多 个 字段 下 的 数据 ， 只 需要 在 关键 字 SELECT 后 面 指定 要 查找 
的 字段 的 名 称 ， 不 同 字 段 名 称 之 间 用 逗号 (，) 分 隔 开 ， 最 后 一 个 字段 后 面 不 需要 加 逗号 ， 语 法 格 
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式 如 下 : 
SELECT 字段 名 1, 字段 名 2, .…, 字段 名 n FROM 表 名 ; 
【 例 17.15】 从 fruits 表 中 获取 f_name 和 f_price 两 列 ，SQL 语句 如 下 : 
SELECT f name, f price FROM fruits; 
该 语句 使 用 SELECT 声明 从 fruits 表 中 获取 名 称 为 f name 和 f_price 两 个 字段 下 的 所 有 水 果 名 
称 和 价格 ， 两 个 字段 之 间 用 逗号 分 隔 开 ， 查 询 结果 如 下 : 


mysql> SELECT f name, f price FROM fruits; 





+------------ +--- 一 -一 一 一 + 
f_name | fprice | 
+------------ +--------- + 
apple | -|| 
apricot | 这 和 可由 
blackberry | T0200 
berry | a || 
er | < el 1 | 
orange 1 | 
melon 1 8520 1 
cherry | 六 时 加 | 
lemon 1 6.40 | 
| mango LO | 
| xbabay | 2=60000| 
| | | 
| coconut | 9.20 1 
| banana 由 SO 
| grape | | 
| xbababa | 35600 1 
+------------ +--------- 十 


输出 结果 显示 了 fruits 表 中 f name 和 人 price 两 个 字段 下 的 所 有 数据 。 


MySQL 中 的 SQL 语句 是 不 区 分 大 小 写 的 ， 因此 SELECT 和 select 作用 是 相同 的 ， 
但 是 ， 许 多 开发 人 员 习 惯 将 关键 字 使 用 大 写 ， 而 数据 列 和 表 名 使 用 小 写 ， 读 者 也 
提 示 。 应 该 养 成 一 个 良好 的 编程 习惯 ， 这样 写 出 来 的 代码 便于 阅读 和 维护 。 


17.4.3 ”查询 指定 记录 
数据 库 中 包含 大 量 的 数据 ， 根 据 特殊 要 求 ， 可 能 只 需 查询 表 中 的 指定 数据 ， 即 对 数据 进行 过 
滤 。 在 SELECT 语句 中 通过 WHERE 子 句 ， 对 数据 进行 过 滤 ， 语 法 格式 为 : 


SELECT 字段 名 1, 字段 名 2, .…, 字段 名 n 
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FROM 表 名 
WHERE 查询 条 件 


在 WHERE 子 句 中 ，MySQL 提供 了 一 系列 的 条 件 判断 符 ， 如 表 17-1 所 示 。 
表 17-1 WHERE 条件 判断 符 


操作 符 








小 于 
小 于 或 者 等 于 
> 大 于 
【 例 17.16】 查 询 价格 为 10.2 元 的 水 果 的 名 称 ，SQL 语句 如 下 : 


SELECT f name, f price 

FROM fruits 

WHERE f£ price = 10.2; 

该 语句 使 用 SELECT 声明 从 fruits 表 中 获取 价格 等 于 10.2 的 水 果 的 数据 ， 从 查询 结果 可 以 看 
到 价格 是 10.2 元 的 水 果 的 名 称 blackberry， 其 他 的 均 不 满足 查询 条 件 ， 查 询 结果 如 下 : 











mysql> SELECT f name, f price 
-> FROM fruits 
-> WHERE f Price = 10.2; 


+----------- + 一 -一 一- 一 一 一 + 
| £_name 1 £ price | 
+ 一 -一 一 一 一 一 一 一 一 一 一 + 一 -一 一 一 一 一 一 + 
| blackberry | ph | 
+------------ + 一 -一 一 一 一 一 一 + 


本 例 采 用 了 简单 的 相等 过 滤 ， 查 询 一 个 指定 列 f_price 具有 值 10.20。 
相等 还 可 以 用 来 比较 字符 串 。 


【 例 17.17】 查 找 名 称 为 apple 的 水 果 的 价格 ，SQL 语句 如 下 : 





SELECT f _ name, f price 
FROM fruits 
WHERE f_ name = 'apple'; 


该 语句 使 用 SELECT 声明 从 fruits 表 中 获取 名 称 为 apple 的 水 果 的 价格 ， 从 查询 结果 可 以 看 到 
只 有 名 称 为 apple 行 被 返回 ， 其 他 的 均 不 满足 查询 条 件 。 


mysql> SELECT f name, f price 
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-> FROM fruits 

-> WHERE f name = 'apple'; 
+ 一 -一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 + 
1 £ name | £f price | 
+-------- 十 ~ 一 一 一 一 一 一 一 一 + 
| apple | 5:20 | 
+-------- +--------- 十 


【 例 17.18】 查 询 价 格 小 于 10.00 元 的 水 果 的 名 称 ，SQL 语句 如 下 : 


SELECT f name, f price 
FROM fruits 
WHERE f price < 10.00; 


该 语句 使 用 SELECT 声明 从 fruits 表 中 获取 价格 低 于 10.00 元 的 水 果 名 称 , 即 人 _price 小 于 10.00 
的 水 果 信 息 被 返回 ， 查 询 结果 如 下 : 
mysql> SELECT f name, f price 


-> FROM fruits 
-> WHERE f£ price < 10.00; 





+--------- +- 一 -一 一- 一- + 
f name | f price | 

+--------- +--------- 十 
apple | 5 20 
apricot | DR 
berry | 0 | 
XE | 3.60 | 
melon | B20 UL 
cherry | cr 41 | 
lemon | 6.40 | 
xbabay | 2.60 | 
coconut | 9.20 | 
grape | 5.30 | 
xbababa | 3.60 | 

+--------- + 一 一 一 一 一 一 一 一 一 + 


可 以 看 到 查询 结果 中 所 有 记录 的 f_price 字段 的 值 均 小 于 10.00 元 。 而 大 于 10.00 元 的 记录 没有 
被 返回 。 
17.4.4 带 IN 关键 字 的 查询 


IN 操作 符 用 来 查询 满足 指定 条 件 范围 内 的 记录 。 使 用 IN 操作 符 时 , 将 所 有 检索 条 件 用 括号 括 
起 来 ， 检 索 条 件 用 逗号 分 隔 开 ， 只 要 满足 条 件 范 围 内 的 一 个 值 即 为 匹配 项 。 


【 例 17.19】 查询 s id 为 101 和 102 的 记录 ，SQL 语句 如 下 : 





查询 结果 如 下 : 


相反 地 ， 可 以 是 用 关键 字 NOT 来 检索 不 在 条 件 范围 内 的 记录 。 
【 例 17.20】 查 询 所 有 s_id 不 等 于 101 也 不 等 于 102 的 记录 ，SQL 语句 如 下 : 


查询 结果 如 下 : 


可 以 看 到 ， 该 语句 在 IN 关键 字 前 面 加 上 了 NOT 关键 字 ， 这 使 得 查询 的 结果 与 前 面 一 个 的 结 
果 正 好 相反 ， 前 面 检索 了 s_id 等 于 101 和 102 的 记录 ， 而 这 里 所 要 求 的 查询 的 记录 中 的 s_id 字段 


oe 
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值 不 等 于 这 两 个 值 中 的 任 一 个 。 
17.4.5 带 BETWEEN AND 的 范围 查询 


BETWEEN AND 用 来 查询 某 个 范围 内 的 值 ， 该 操作 符 需 要 两 个 参数 ， 即 范围 的 开始 值 和 结束 
如 果 记 录 的 字段 值 满足 指定 的 范围 查询 条 件 ， 则 这 些 记 录 被 返回 。 
【 例 17.21】 查 询 价格 在 2.00 元 到 10.5 元 之 间 水 果 名 称 和 价格 ，SQL 语句 如 下 : 

















值 


SELECT f name, f price FROM fruits WHERE f price BETWEEN 2.00 AND 10.20; 
查询 结果 如 下 : 
mysql> SELECT f name, f price 


-> FROM fruits 
-> WHERE f price BETWEEN 2.00 AND 10.20; 





+------------ +---------: 十 
f name | £ price | 

+------------ +--------- + 
apple | | 
apricot | 252000 | 
blackberry | L020e ul 
berry 1 Te60 |] 
XxX 1 3.60 
melon 1 2 
cherry | 200 | 
lemon | 6.40 | 
xbabay | 2.60 | 
coconut 1 ge200| 
grape 1 5.30 | 
xbababa | 3.605 

+------------ +---------: 十 


可 以 看 到 , 返回 结果 包含 了 价格 从 2.00 元 到 10.20 元 之 间 的 字段 值 ,并 且 端点 值 10.20 也 包括 
在 返回 结果 中 ， 即 BETWEEN 匹配 范围 中 所 有 值 ， 包 括 开 始 值 和 结束 值 。 
BETWEEN AND 操作 符 前 可 以 加 关键 字 NOT, 表示 指定 范围 之 外 的 值 ， 如 果 字 段 值 不 满足 指 
定 的 范围 内 的 值 ， 则 这 些 记录 被 返回 。 
【 例 17.22】 查 询 价格 在 2.00 元 到 10.5 元 之 外 的 水 果 名 称 和 价格 ，SQL 语句 如 下 : 


SELECT f name，f price 
FROM fruits 
WHERE f price NOT BETWEEN 2.00 RND 10.20; 


查询 结果 如 下 : 


+ 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 + 
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| £ name | f price | 


+=-—- 一 一 一 一 二 -一 一 一 一 一 一 一 一 + 
| orange | 11.20 | 
| mango | | 
Uxxtt | | 
| banana | 10.30 | 
+-------- + 一 一 一 一 一 一 一 一 一 + 


由 结果 可 以 看 到 , 返回 的 记录 只 有 f_price 字段 大 于 10.20 的 ，f_price 字段 小 于 2.00 的 记录 也 
满足 查询 条 件 ， 因 此 如 果 表 中 有 f_price 字段 小 于 2.00 的 记录 ， 也 应 当 作为 查询 结果 。 
17.4.6 带 LIKE 的 字符 匹配 查询 

在 前 面 的 检索 操作 中 ， 讲 述 了 如 何 查询 多 个 字段 的 记录 ， 如 何 进行 比较 查询 或 者 查询 一 个 条 
件 范围 内 的 记录 ， 如 果 要 查找 所 有 的 包含 字符 “ge” 的 水 果 名 称 ， 该 如 何 查找 呢 ? 简单 的 比较 操作 
在 这 里 已 经 行 不 通 了 , 在 这 里 , 需要 使 用 通配符 进行 匹配 查找 , 通过 创建 查找 模式 对 表 中 的 数据 进 
行 比较 。 执 行 这 个 任务 的 关键 字 是 LIKE。 

通配符 是 一 种 在 SQL 的 WHERE 条 件 子 句 中 拥有 特殊 意思 的 字符 ,SQL 语句 中 支持 多 种 通 配 
符 ， 可 以 和 LIKE 一 起 使 用 的 通配符 有 “% ”和 “_”。 

1. 百 分 号 通配符 “%”， 匹 配 任意 长 度 的 字符 ， 甚 至 包括 零 字 符 

【 例 17.23】 查 找 所 有 以 “b” 字 和 母 开头 的 水 果 ，SQL 语句 如 下 : 


SELECT f _id, f_name 
FROM fruits 
WHERE f _ name LIKE 'b%'; 


查询 结果 如 下 : 





+ 一 -一 一- 一 +------------ + 


1fid | f name 1 


+------ +------------ 十 
| bl | blackberry | 
| 图” | berry || 
| tl | banana | 
+------ +------------ 十 


该 语句 查询 的 结果 返回 所 有 以 “b” 开 头 的 水 果 的 id 和 name，“% ”告诉 MySQL， 返 回 所 有 
f name 字段 以 字母 “b” 开 头 的 记录 ， 不 管 “b” 后 面 有 多 少 个 字符 。 
在 搜索 匹配 时 通配符 “%” 可 以 放 在 不 同位 置 。 


【 例 17.24】 在 fruits 表 中 ， 查 询 f_name 中 包含 字母 “g” 的 记录 ，SQL 语句 如 下 : 





SELECT f id, f name 
FROM fruits 
WHERE f name LIKE '%g%'; 
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查询 结果 如 下 : 
+------ +-------- 十 


lf£fid | f£ name | 


+ 一 -一 一 一 一 + 一 一 一 一 一 一 一 一 + 
| bsl | orange | 
| ml | mango | 
| t2 | grape | 
+------ 二 -一 一 一 一 一 一 一 十 


该 语句 查询 包含 字符 串 中 包含 字母 “g” 的 水 果 名 称 ， 只 要 名 字 中 有 字符 “g”， 而 前 面 或 后 
面 不 管 有 多 少 个 字符 ， 都 满足 查询 的 条 件 。 
【 例 17.25】 查 询 以 “b” 开 头 ， 并 以 “y” 结 尾 的 水 果 的 名 称 ，SQL 语句 如 下 : 


SELECT f_name 
FROM fruits 
WHERE 工 name LIKE ‘'b%y'; 


查询 结果 如 下 : 


+------------ 十 
| £ name 1 
+------------ 十 
| blackberry | 
| berry | 
+------------ 十 


通过 以 上 查询 结果 ， 可 以 看 到 ，“%” 用 于 匹配 在 指定 的 位 置 的 任意 数目 的 字符 。 

2. 下 划 线 通配符 “_'， 一 次 只 能 匹配 任意 一 个 字符 

另 一 个 非常 有 用 的 通配符 是 下 划 线 通配符 “_”， 该 通配符 的 用 法 和 “%” 相 同 ， 区 别 是 “%? 
匹配 多 个 字符 , 而 “_” 只 匹配 任意 单个 字符 ， 如果 要 匹配 多 个 字符 ， 则 需要 使 用 相同 个 数 的 “_”。 

【 例 17.26】 在 fruits 表 中 ， 查 询 以 字母 “y” 结 尾 ， 且 “y” 前 面 只 有 4 个 字母 的 记录 ，SQL 
语句 如 下 : 


SELECT f _id, f name FROM fruits WHERE f name LIKE '_ _ _ _y'; 
查询 结果 如 下 : 
+ 一 -一 一- 一 二- 一 一 一 一 一 一 一 + 


1fid | name | 


i'b2 | berry | 
en md 


从 结果 可 以 看 到 ， 以 “y” 结 尾 且 前 面 只 有 4 个 字母 的 记录 只 有 一 条 。 其 他 记录 的 fname 字 
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段 也 有 以 “y” 结 尾 的 ， 但 其 总 的 字符 串 长 度 不 为 5， 因 此 不 在 返回 结果 中 。 
17.4.7 ”查询 空 值 


创建 数据 表 的 时 候 ， 设 计 者 可 以 指定 某 列 中 是 否 可 以 包含 空 值 (NULL) ， 空 值 不 同 于 0， 也 
不 同 于 空 字符 串 ， 空 值 一 般 表 示 数 据 未 知 、 不 适用 或 将 在 以 后 添加 数据 。 在 SELECT 语句 中 使 用 





IS NULL 子 句 ， 可 以 查询 某 字段 内 容 为 空 记录 。 


【 例 17.27】 查 询 customers 表 中 c_email 为 空 的 记录 的 c_id、c_name 和 c_email 字段 值 ，SQL 


语句 如 下 : 
SELECT ¢c _ id, c name,c email FROM customers WHERE c email IS NULL; 
查询 结果 如 下 : 


mysql> SELECT c¢c id, c name,c email FROM customers WHERE c¢c email IS NULL; 


+----- 一 - +----------- +--------- + 
lcid | cname | c_email | 
+------- +----------- +--------- + 
| 10003 | Netbhood | NULL 1 
+------- +----------- +--------- + 


可 以 看 到 ， 显 示 customers 表 中 字段 c_email 的 值 为 NULL 的 记录 ， 满 足 查询 条 件 。 
与 IS NULL 相反 的 是 NOT IS NULL， 该 关键 字 查 找 字 段 不 为 空 的 记录 。 


【 例 17.28】 查 询 customers 表 中 c_email 不 为 空 的 记录 的 c_id、c_name 和 c_email 字段 值 , SQL 


语句 如 下 : 
SELECT ¢c_id, c name,c email FROM customers WHERE ¢ email IS NOT NULL; 


查询 结果 如 下 : 


mysql> SELECT ¢c id, c name,c email FROM customers WHERE c email IS NOT NULL; 


+---- 一 一- +--------- +------------------- 十 
lcid 1 cname | c_email 1 

+ 一 -一 一 一 一 一 +--------- +------------------- 十 
| 10001 | RedHook | LMing@163.com 1 

| 10002 | Stars | Jerry@hotmail.com | 
| 10004 | JOTO | sam@hotmail .com | 
+ 一 -一 一 一 一 一 +--------- +------------------- 十 


可 以 看 到 ， 查 询 出 来 的 记录 的 c_email 字段 都 不 为 空 值 。 
17.4.8 带 AND 的 多 条 件 查 询 
使 用 SELECT 查询 时 ， 可 以 增加 查询 的 限制 条 件 ， 这 样 可 以 使 查询 的 结果 更 加 精确 。MySQL 


在 WHERE 子 句 中 使 用 AND 操作 符 限定 只 有 满足 所 有 查询 条 件 的 记录 才 会 被 返回 。 可 以 使 用 AND 


连接 两 个 甚至 多 个 查询 条 件 ， 多 个 条 件 表达 式 之 间 用 AND 分 开 。 
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【 例 17.29】 在 fruits 表 中 查询 s id = 101， 并 且 f price 大 于 5 的 记录 价格 和 名 称 ，SQL 语句 
如 下 : 
SELECT s_id, f price, f _ name FROM fruits WHERE s id = '101' AND f price >=5; 
查询 结果 如 下 : 
mysql> SELECT s id, f price, f name 
-> FROM fruits 
-> WHERE s id = '101' AND f price >= 5; 
+--- 一 一 十 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 
lsid | fprice | f name | 
+-----=: 二 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 一 一 + 
| 101 | 5.20 | apple | 
WOL | 10.20 | blackberry | 
+------ + 一 -一 一 一 一 一 一 +- 一 -一 一 一 一 一 一 一 一 一 + 


前 面 的 语句 检索 了 s_id=101 的 水 果 供应 商 所 有 价格 大 于 等 于 5 元 的 水 果 名 称 和 价格 。WHERE 
子 句 中 的 条 件 分 为 两 部 分 ，AND 关键 字 指 示 MySQL 返回 所 有 同时 满足 两 个 条 件 的 行 。 即 使 是 
s_id=101 的 水 果 供应 商 提供 的 水 果 ， 价 格 <5 或 者 s id 不 等 于 “101” 的 水 果 供 应 商 的 水 果 不 管 其 价 
格 为 多 少 ， 均 不 是 要 查询 的 结果 。 


上 述 例子 的 WHERE 子 句 中 只 包含 了 一 个 AND 语句 ， 把 两 个 过 滤 条 件 组 合 在 一 起 。 
实际 上 可 以 添加 多 个 AND 过 滤 条 件 ， 增 加 条 件 的 同时 增加 一 个 AND 关键 字 。 
提 示 
【 例 17.30】 在 fruits 表 中 查询 s id = 101 或 者 102， 并 且 f_price 大 于 5, f name= “apple” 的 
记录 的 价格 和 名 称 ，SQL 语句 如 下 : 
SELECT f id, f price, f name FROM fruits 
WHERE s_id IN('101', '102') AND f price >= 5 AND f name = 'apple'; 
查询 结果 如 下 : 
mysql> SELECT f id, f price, f name FROM fruits 
-> WHERE s_id IN('101','102') AND f price >= 5 AND f name = 'apple'; 
+ 一 -一 一- 一 +--------- +-------- + 
1 sid | f price | f name | 
刷 二 === 守 二 过 二 一 一 一 一 二 一 一 全 中 二 和 


(i | 5.20 | apple | 
+-- 一 一- 二 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 + 


可 以 看 到 返回 符合 查询 条 件 的 记录 只 有 一 条 。 
17.4.9 带 OR 的 多 条 件 查 询 
与 AND 相反 , 在 WHERE 声明 中 使 用 OR 操作 符 ， 表 示 只 需要 满足 其 中 一 个 条 件 的 记录 即 可 
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返回 。OR 也 可 以 连接 两 个 甚至 多 个 查询 条 件 ， 多 个 条 件 表 达 式 之 间 用 OR 分 开 。 

【 例 17.31】 查 询 s_id=101 或 者 s_id=102 的 水 果 供应 商 的 f_ price 和 f name，SQL 语句 如 下 : 
SELECT s id,f name, f price FROM fruits WHERE s_ id = 101 OR s id = 102; 
查询 结果 如 下 : 
mysql> SELECT s id,f name, f price 


-> FROM fruits 
-> WHERE s id = 101 OR s id = 102; 


+------ 二 -一 一 一 一 一 一 一 一 一 一 一 +---- 一 一 一 一 + 
| s_id | f name | fprice | 
+------ 二 -一 一 一 一 一 一 一 一 一 一 一 +----- 一 -一 + 
| 101 | apple 1 4 1 || 
| 101 | blackberry | T0200 | 
| 102 | orange | Ti 20. 4 
| 101 | cherry | = || 
| 102 | banana | 10530 | 
| 102 | grape | || 
+------ +------------ +--------- + 


结果 显示 查询 了 s_id=101 和 s_id=102 的 供应 商 提 供 的 水 果 名 称 和 价格 ，OR 操作 符 告诉 
MySQL， 检 索 的 时 候 只 需要 满足 其 中 的 一 个 条 件 ， 不 需要 全 部 者 满足， 如果 这 里 使 用 AND 的 话 ， 
将 检索 不 到 符合 条 件 的 数据 。 

在 这 里 ， 也 可 以 使 用 IN 操作 符 实现 与 OR 相同 的 功能 ， 下 面 的 例子 可 进行 说 明 。 

【 例 17.32】 查 询 s_id=101 或 者 s_id=102 的 水 果 供应 商 的 f name 和 f price，SQL 语句 如 下 : 

SELECT s_id,f name, f price FROM fruits WHERE s_id IN(101,102); 

查询 结果 如 下 : 

mysql> SELECT s id,f name, f price 


-> FROM fruits 
-> WHERE s_id IN(101,102); 


+------ +------------ +- 一 -一 一 一 一 一 一 + 
1 s_id | f name lf price | 
+-- 一 一- + 一 -一 一 一 一 一 一 一 一 一 + 一 一- 一 一 一 一 一 一 + 
| 101 | apple 1 5s20° | 

| 101 | blackberry | L020 
| 102 | orange | L200 
| 101 | cherry 1 3520 | 

| 102 | banana | 
| 102 | grape | S530 | 

+ 一 -一 一- 十 -一 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 + 





在 这 里 可 以 看 到 ，OR 操作 符 和 IN 操作 符 使 用 后 的 结果 是 一 样 的 ,它们 可 以 实现 相同 的 功能 。 
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但 是 使 用 IN 操作 符 使 得 检索 语句 更 加 简洁 明了 ， 并 且 IN 执行 的 速度 要 快 于 OR， 更 重要 的 是 , 使 
用 IN 操作 符 后 ， 可 以 执行 更 加 复杂 的 嵌 套 查询 (后面 章 节 将 会 讲述 )。 





C0 OR 可 以 和 AND 一 起 使 用 ， 但 是 在 使 用 时 要 注意 两 者 的 优先 级 ， 由 于 AND 的 优先 级 


提示 高 于 OR， 因 此 先 对 AND 两 边 的 操作 数 进行 操作 ， 再 与 OR 中 的 操作 数 结 合 。 
人 J\ 


17.4.10 ”查询 结果 不 重复 
从 前 面 的 例子 可 以 看 到 ，SELECT 查询 返回 所 有 匹配 的 行 。 例 如 查询 fruits 表 中 所 有 的 s_id， 








卢 
[= 
CO 


可 以 看 到 查询 结果 返回 了 16 条 记录 ， 其 中 有 一 些 重复 的 s_ id 值 ， 有 时 ， 出 于 对 数据 分 析 的 要 
求 , 需要 消除 重复 的 记录 值 , 如 何 使 查询 结果 没有 重复 呢 ? 在 SELECT 语句 中 可 以 使 用 DISTINCT 
关键 字 指 示 MySQL 消除 重复 的 记录 值 。 语 法 格式 为 : 


SELECT DISTINCT 字段 名 FROM 表 名 ; 

【 例 17.33】 查 询 fruits 表 中 s_id 字段 的 值 ， 并 返回 s id 字段 值 不 得 重复 ，SQL 语句 如 下 : 
SELECT DISTINCT s_id FROM fruits; 

查询 结果 如 下 : 


mysql> SELECT DISTINCT s_id FROM fruits; 











可 以 看 到 这 次 查询 结果 只 返回 了 7 条 记录 的 s id 值 ， 而 不 再 有 重复 的 值 ，SELECT 
DISTINCE s id 告诉 MySQL 只 返回 不 同 的 s id 值 。 
17.4.11 ”对 查询 结果 排序 


从 前 面 的 查询 结果 ,读者 会 发 现 有 些 字段 的 值 是 没有 任何 顺序 的 , MySQL 中 可 以 通过 SELECT 
使 用 ORDER BY 子 句 对 查询 的 结果 进行 排序 。 


1. 单列 排序 
例如 ， 查 询 f_name 字段 ， 查 询 结 果 如 下 : 
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可 以 看 到 ， 查 询 的 数据 并 没有 以 一 种 特定 的 顺序 显示 ， 如 果 没 有 对 它们 进行 排序 ， 将 根据 它 
们 插入 到 数据 表 中 的 顺序 来 显示 。 
下 面 使 用 ORDER BY 子 句 对 指定 的 列 数据 进行 排序 。 


【 例 17.34】 查 询 fruits 表 的 


f_name 字段 值 ， 并 对 其 进行 排序 ，SQL 语句 如 下 : 


mysql> SELECT f name FROM fruits ORDER BY f name; 


| apPle 1 
| apricot | 
| banana | 
| berry | 
| blackberry | 
| cherry | 
| coconut | 
| grape 
| lemon 
| mango 
| melon 
| orange | 
| xbababa | 
1 

1 

1 


该 语句 查询 的 结果 和 前 面 的 语句 相同 ， 不 同 的 是 ， 通 过 指定 ORDER BY 子 句 ，MySQL 对 查 
询 的 f_name 列 的 数据 按 字 母 表 的 顺序 进行 了 升序 排序 。 


2. 多 列 排序 


有 时 ， 需 要 根据 多 列 值 进行 排序 。 例 如 ， 如 果 要 显示 一 个 学 生 列表 ， 可 能 会 有 多 个 学 生 的 姓 


氏 是 相同 的 ,因此 还 需要 根据 学 和 
用 逗号 隔 开 。 





的 名 进行 排序 。 对 多 列 数据 进行 排序 ， 只 要 将 需要 排序 的 列 之 间 


【 例 17.35】 查 询 fruits 表 中 的 f_name 和 f_price 字段 ， 先 按 f name 排序 ， 再 按 f_price 排序 ， 


SQL 语句 如 下 : 
SELECT f name, f price 


查询 结果 如 下 : 


FROM fruits ORDER BY f name, f price; 


mysql> SELECT f name, f price FROM fruits ORDER BY f name, f price; 


二 -一 一 一 一 一 一 一 一 一 一 一 + 一 一 -一 一 一 一 一 一 + 
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| £f_name pricedl 
+ 一- 一 一 一 一 一 一 一 一 一 一 + 一 一 -一 一 一 一 一 一 + 
| apple | S20 0| 
| apricot | 2 
| banana (| 
| berry | T6000 | 
| blackberryl T0200 
| cherry | 3.200| 
| coconut | 9.20 | 
| grape | 55307 1 
| lemon | 6.40 1 
| mango | 15.600| 
| melon | 8=20°0 | 
| orange | T2200] 
| xbababa | On 
| xbabay | 2.60 | 
| xxtt | | 
| xxxx | 3.60 | 
+------------ +--------- 十 


0 在 对 多 列 进行 排序 的 时 候 ， 首 先 排 序 的 第 一 列 必须 有 相同 的 列 值 ， 才 会 对 第 二 列 进 行 
排序 ， 如 果 第 一 列 数据 中 所 有 值 都 是 唯一 的 ， 将 不 再 对 第 二 列 进 行 排序 。 


示 

3. 指定 排序 方向 

默认 情况 下 ， 查 询 数据 按 字 母 升序 进行 排序 (从 A 到 Z) ， 但 数据 的 排序 并 不 仅 限 于 此 ， 还 
可 以 使 用 ORDER BY 对 查询 结果 进行 降序 排序 (从 Z 到 A〉， 这 通过 关键 字 DESC 实现 ， 下 面 的 
例子 表明 了 如 何 降序 排列 。 

【 例 17.36】 查 询 fruits 表 中 的 f name 和 ff price 字段 ， 对 结果 按 f_price 降序 方式 排序 ，SQL 
语句 如 下 : 

SELECT f name, f price FROM fruits ORDER BY f price DESC; 

查询 结果 如 下 : 


mysql> SELECT f name, f price FROM fruits ORDER BY f price DESC; 


+------------ + 一 一- 一 一 一 一 一 一 + 
| £ name | £ price | 
+------------ +--------- 十 
| mango | L560) | 
| xxtt 1 31.60 1 
| orange 1 | 
| banana os300 
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提 示 
也 可 以 对 多 列 进行 不 同 的 顺序 排序 。 
【 例 17.37】 查 询 fruits 表 ， 先 按 f_price 降序 排序 ， 再 按 f_ name 字段 升序 排序 ，SQL 语句 如 


查询 结果 如 下 : 
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DESC 排序 方式 只 应 用 到 直接 位 于 其 前 面 的 字段 上 ， 由 结果 可 以 看 到 。 
0 DESC 关键 字 只 对 其 前 面 的 列 降序 排列 ,在 这 里 只 对 fprice 排序 ,而 并 没有 对 fname 


进行 排序 ， 因 此 ，f price 按 降序 排序 ， 而 f name 列 仍 按 升序 排序 。 如果 要 对 多 列 都 
提 示 。 进行 降序 排序 ， 必 须要 在 每 一 列 的 列 名 后 面 加 DESC 关键 字 。 


17.5 “实战 演练 一 一 数据 表 综 合 应 用 案例 
此 案例 根据 不 同 的 条 件 对 表 进 行 查询 操作 ， 涉 及 的 表 如 表 17-2~ 表 17-5 所 示 。 


表 17-2 employee 表 结 构 


FT 
耕 


全 
a 下 后 


[niepae | Am |pAr | |i | 


























































eno ename e gender dept_no e job hireDate 
m CLERK 2005-11-12 
f [30 [saLESMAN | 2003-05-12 
f 0 SALESMAN 2003-05-12 
1004 JONES m MANAGER 2975 1998-05-18 
1005 MARTIN m SALESMAN 1250 2001-06-12 
1006 BLAKE 人 MANAGER 2850 1997-02-15 
1007 CLARK m MANAGER 2450 2002-09-12 
1008 SCOTT m ANALYST 3000 2003-05-12 
1009 KING 二 PRESIDENT 5000 1995-01-01 
1010 TURNER 过 SALESMAN 1500 1997-10-12 
1011 ADAMS m CLERK 1100 1999-10-05 
1012 JAMES f CLERK 950 2008-06-15 
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表 17-5 dept 表 中 的 记录 


| name d_location 


dno 
ACCOUNTING 
RESEARCH 














SALES 
40 OPERATIONS 


案例 操作 过 程 如 下 。 
创建 数据 表 employee 和 dept。 


CREATE TABLE dept 

( 
dno INT NOT NULL PRIMARY KEY AUTO _ INCREMENT, 
d name VARCHAR (50)NOT NULL, 
qd location VARCHAR(100) 

LE 


由 于 employee 表 中 的 dept_no 依赖 于 父 表 dept 的 主键 d_no,， 因此 需要 先 创建 dept 表 , 然后 创 
建 employee 表 。 


CREATE TABLE employee 

( 
eno INT NOT NULL PRIMARY KEY, 
e_name VARCHAR (100) NOT NULL, 
e gender CHAR(2) NOT NULL, 
dept_no INT NOT NULL, 
e_job VRARCHAR (100) NOT NULL, 
e_salary SMALLINT NOT NULL, 
hireDate DATE, 
CONSTRAINT dno fk FOREIGN KEY(dept_no) 
REFERENCES dept(d_no) 

| 


思 将 指定 记录 分 别 插入 两 个 表 中 。 
向 dept 表 中 插入 数据 ，SQL 语句 如 下 : 


INSERT INTO dept 

VALUES (10, 'ACCOUNTING', 'ShangHai'), 
(20, 'RESEARCH ', 'BeiJing '), 
(30, 'SALES ', 'ShenZzhen '), 
(40, 'OPERATIONS ', "FuJian '); 


向 employee 表 中 插入 数据 ，SQL 语句 如 下 : 
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INSERT INTO employee 
VALUES (1001, 'SMITH' 
(1002, 'ALLEN', 
(1003, 'WARD', 
(1004, 'JONES', 
(1005, 'MRRTIN' 
(1006, 'BLAKE', 
(1007, 'CLARK', 
(1008, 'SCOTT', 'm',20, 'ANALYST', 
(1009, 'KING', 'f',10, 'PRESIDENT', 
(1010, 'TURNER', '‘'f',30, 'SALESMAN' 
(1011, 'ADAMS', 'm',20, 'CLERK', 
(1012, 'JAMES', 'm',30, 'CLERK', 


'm',20, 
wae 
E30 
'm',20, 
'm',30, 
WE 0 
m',10, 


'SALESMAN', 
'SALESMAN', 
'MANAGER', 

"SALESMRAN 
"MARNRGER '， 
'MANAGER', 


"CLERK';800;"2005-=11-12"); 


1600,'2003-05-12')， 
1250,'2003-05-12')，, 
2975, '1998-05-18')，, 
，1250, '2001-06-12'), 
2850,'1997-02-15')， 
2450,'2002-09-12')， 
3000, '2003-05-12')， 
5000,'1995-01-01'), 
1500, '1997-10-12'), 


1100,'1999-10-05'), 
950, '2008-06-15'); 


贺 在 employee 表 中 ， 查 询 所 有 记录 的 e no、e_name 和 e_salary 字段 值 。 


SELECT e_no，e_name，e_salary FROM employee; 


执行 结果 如 下 : 





mysql> SELECT @ no, e name, e salary FROM 
+------ +--------: +---------- + 
e no | e name | e salary | 
+------ +--------: +---------- + 
1001 | SMITH | 800 | 
1002 | ALLEN | 1600 | 
1003 | WARD | 1250 | 
1004 | JONES | | 
1005 | MARTIN | 1250 1 
1006 | BLAKE | 2850 | 
1007 | CLARK | 2450 | 
1008 | SCOTT | 3000 | 
1009 | KING | 5000 | 
1010 | TURNER | 1500 | 
1011 | ADAMS | 4100 | 
1012 | JAMES | 950 | 
中 ~ 一 市 二 一 二 二 二 二 二 天 二 二 二 一 关 二 全 一 汪 + 


12 rows in set (0.00 sec) 


employee; 


在 employee 表 中 ， 查 询 dept_no 等 于 10 和 20 的 所 有 记录 。 


SELECT * FROM employee WHERE dept no IN (10, 20); 


执行 结果 如 下 : 
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mysql> SELECT * 








FROM employee WHERE dept no IN (10, 20); 


+--——== + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 一 + 
| e_no | e name | e gender | dept no | e job | e salary | hireDate | 
+ 

V00U lH SMITH | m 1 20 | CLERK | 800 | 

| 1004 | JONES | mm 1 20 | MANAGER | 2975 1 998=05=18; 1 

| 1007 | CLARK | m 1 10 | MANAGER | 2450012002=09=12 | 

OO SeoOrT Wm | 20 | ANALYST | 30000 1 :2003=0512 | 

| 1009 | KING [J | 10 | PRESIDENT | 5000 | 1995-01-01 

| 1011 | ADAMS | mm | 20 | CLERK | 1100 | 1999=10=05" 1 

+------ +- 一 一 一 一 一 一 一 +- 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 +---------- 一 + 

6 rows in set (0.00 sec) 

加 在 employee 表 中 ， 查 询 工 资 范围 在 800 到 2500 之 间 的 员工 信息 。 

SELECT * FROM employee WHERE ee salary BETWEEN 800 AND 2500; 

执行 结果 如 下 : 

mysql> SELECT * FROM employee WHERE e salary BETWEEN 800 AND 2500; 

+------ +-------- +---------- +--------- +---------- +---------- +----------- 十 
e_no | e_name | e gender | dept no | e_job | e_salary | hireDate | 

+------ +-- 一 -一 一 一 一 +-- 一 -一 一 一 +--- 一 -一 +------- 一 一 +-- 一 -一 -一 一 一 一 +----------- 十 
1001 | SMITH | m | 20 | CLERK | 800 N2005=324=32 
1002 | ALLEN | f | 30 | SALESMAN | 1600 N2003=05=12 
1003 | WARD ee: 1 30 | SALESMAN | 1250 122003=05=32 
1005 | MARTIN | m | 30 | SALESMAN | 1250 1 2001-06-12 | 
1007 | CLARK | m | 10 | MANAGER | 2450 1 2002-09-12 
1010 | TURNER | f 1 30 | SALESMRAN1 1500 1 1997=10=12> 1 
1011 | ADAMS | m 1 20 | CLERK | 1100 1 1999=10=05 | 
1012 | JAMES | m 1 30 | CLERK 1 950 | 2008-06-15 | 

+------ + 一 -一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 +- 一 一 一 一 一 一 一 一 +- 一 一 一 一 一 一 一 一 + 一- 一 一 一- 一 一 一 +------------ 十 

8 rows in set (0.00 sec) 

四 在 employee 表 中 ， 查 询 部 门 编号 为 20 的 部 门 中 的 员工 信息 。 

SELECT * FROM employee WHERE dept no = 20; 

执行 结果 如 下 : 

mysql> SELECT * FROM employee WHERE dept no = 20; 

+-- 一 -一 + 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 4- 一 -一 一 一 一 一 一 一 一 一 + 

| e_no | e name | e gender | dept no | e job | e salary | hireDate 1 

+ 一 -一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 一 +- 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 +------------ + 
| 1001 | SMITH | m | 20 | CLERK | 800 上 005= 过 二 2 
| 1004 | JONES | m | 20 | MANAGER | vd | 


1 
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| 1008 | SCOTT | m 1 20 | ANALYST | 3000 "1 2003=05=12 | 
| 1011 | ADAMS | m | 20 | CLERK | 1100 99 10030 


4 rows in set (0.00 sec) 

在 employee 表 中 ， 查 询 每 个 部 门 最 高 工资 的 员工 信息 。 

SELECT dept _ no, MAX(e salary) FROM employee GROUP BY dept_ no; 
执行 结果 如 下 : 


mysql> SELECT dept no, MAX(e salary) FROM employee GROUP BY dept no; 
+--------- +--------------- 十 
| dept no | MAX(e salary) | 


+--------- +--------------- + 
| LO 5000 | 
| 2 3000 | 
| | 2850 | 
+--------- +--------------- + 


3 rows in set (0.00 sec) 


国 查询 员工 BLAKE 所 在 部 门 和 部 门 所 在 地 。 


SELECT d no, d location FROM dept WHERE d no= 
(SELECT dept_no FROM employee WHERE e name=BLAKE"); 

执行 结果 如 下 : 
mysql> SELECT d _ no, d location 

-> FROM dept WHERE d no= 

-> (SELECT dept_ no FROM employee WHERE e_ name='BLAKE'); 
+------ +------------ 十 
| dno | d location | 
+------ +------------ 十 
| 30 | ShenZhen 1 


1 row in set (0.00 sec) 
国 使 用 连接 查询 ， 查 询 所 有 员工 的 部 门 和 部 门 信息 。 


SELECT € no, e name, dept no, d name,d location 
FROM employee, dept WHERE dept.d no=employee.dept no; 


执行 结果 如 下 : 


mysql> SELECT @& no, e name, dept no, d name,d location 
-> FROM employee, dept WHERE dept.d no=employee.dept no; 
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e no | e_name | dept no | d name | qd location | 

+--—--- 二 -一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 +-- 一 一 一 一 -一 一 一 一 4- 一- 一 一 一 一 一 一 一 + 
1001 | SMITH | 20 | RESEARCH BeiJing 1 
1002 | ALLEN | 30 | SALES | Shenzhen 1 
1003 | WARD | 30 | SALES | ShenZhen 1 
1004 | JONES | 20 | RESEARCH BeiJing 1 
1005 | MARTIN | 30 | SALES Shenzhen | 
1006 | BLAKE | 30 | SALES | ShenZhen 1 
1007 | CLARK | 10 | ACCOUNTING | ShangHai | 

IE3008 IESCcOFT | 20 | RESEARCH BeiJing 1 

| 1009 | KING 1 10 | ACCOUNTING | ShangHai 1 
1010 | TURNER | 30 | SALES Shenzhen | 

| 1011 | ADAMS | 20 | RESEARCH BeiJing 1 

| 1012 | JAMES | 30 | SALES | ShenZhen 1 

+------ + 一- 一 一 一 一 一 +--------- +------------ +------------ + 


12 rows in set (0.00 sec) 

在 employee 表 中 ， 计 算 每 个 部 门 各 有 多 少 名 员工 。 

SELECT dept_ no, COUNT(*) FROM employee GROUP BY dept_no; 
执行 结果 如 下 : 


mysql> SELECT dept no, COUNT(*) FROM employee GROUP BY dept_no; 


| dept no | COUNT(*) | 





3 rows in set (0.00 sec) 

在 employee 表 中 ， 计 算 不 同类 型 职工 的 总 工资 数 。 

SELECT e_job，SUM(e_salary) FROM employee GROUP BY e_job; 
执行 结果 如 下 : 


mysql> SELECT € job, SUM(e_ salary) FROM employee GROUP BY e@ job; 


+----------- +--------------- 十 
lesjiob | SUM(e_salary) | 
+----------- +--------------- 十 
| ANALYST | 3000 | 
| CLERK | 2850 | 
| MANAGER | 273750 
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| PRESIDENT | 5000 | 
| SALESMAN | 5600 | 


5 rows in set (0.00 sec) 

在 employee 表 中 ， 计 算 不 同 部 门 的 平均 工资 。 

SELECT dept_no，RAVG(e_salary) FROM employee GROUP BY dept _ no; 

执行 结果 如 下 : 

mysql> SELECT dept no, AVG(e salary) FROM employee GROUP BY dept _ no; 


+--------- +--------------- 十 
| dept no | AVG(e salary) | 


:二 = 二 了 = 二 = 一 3 一 记 二 二 二 二 二 二 二 二 这 二 二 二 
| ni | 3725.0000 | 
| 20 | 1968.7500 | 
| 30 1 1566.6667 | 
a ee ee er eh a 二 


3 rows in set (0.00 sec) 

园 在 employee 表 中 ， 查 询 工资 低 于 1500 的 员工 信息 。 
SELECT * FROM employee WHERE e_salary < 1500; 
执行 过 程 如 下 : 


mysql> SELECT * FROM employee WHERE e salary < 1500; 





+ 一- 一 + 一 一 一 一 一 一 一 +---------- +--------- +---------- +--------- +------------ 十 
| e_no | e_name | e gender | dept no | e job | e salary| hireDate | 
+----- 一 +-------- +---------- +--------- +---------- +--------- +------------ 十 
| 1001 | SMITH | m 1 20 | CLERK 1 800 | 2005-11-12 

| 1003 | WARD [I | 30 | SALESMAN | F250 2003=053=12 7 
| 1005 | MARTIN | m | 30 | SALESMAN | 1250 | 2001-06-12 | 
| 1011 | ADAMS | m 1 20 | CLERK 1 O00 1999 T0050 
| 1012 | JAMES | m 1 30 | CLERK 1 950 | 2008-06-15 
+------ +-------- + 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 +---------- + 一 一 一- 一 一 +------------ 十 
5 rows in set (0.00 sec) 

在 employee 表 中 , 将 查询 记录 先 按 部 门 编号 由 高 到 低 排列 ,再 按 员工 工资 由 高 到 低 和 


SELECT €@ name,dept no, e salary 
FROM employee ORDER BY dept no DESC, e@ salary DESC; 


执行 过 程 如 下 : 
mysql> SELECT € name,dept no, e salary 
-> FROM employee ORDER BY dept no DESC, e@ salary DESC; 
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+ 一 一 一 一 一 一 一 一 二 一 一 一 一 一 一 一 一 一 +---------- 十 
e name | dept no | e _ salary | 
+-------- +--------- + 一 一 -一 一 一 一 一 + 
BLAKE | 上 | 2850 | 
ALLEN | | 1600 | 
TURNER | 30 1 1500 | 
WARD | S00 uf | 
MARTIN | 30° 1 T2500 
| JAMES | 30 1 950 | 
I seore ll 20 | 3000 | 
JONES | 20 | 人 | 
ADAMS | 20 | 1100 | 
SMITH | 20 1 800 | 
| KING | OA 5000 | 
CLARK | | | 2450 | 
+-------- +--------- +---------- 十 


12 rows in set (0.00 sec) 

在 employee 表 中 ， 查 询 员工 姓名 以 字母 A 或 S 开头 的 员工 的 信息 。 
SELECT * FROM employee WHERE e_name REGEXP '^[as]'; 
执行 过 程 如 下 : 


mysql> SELECT * FROM employee WHERE e name REGEXP '^[as]'; 


+------ +-------- +---------- +-------- 一 +---------- + 一 -一 -一 一 +------------ 十 
| e_no | e_name | e gender | dept no | e_job | e_salary | hireDate | 
+------ + 一 一 一 一 一 一 +---------- +-------- 一 +---------- + 一 -一 -一 -一 一 +------------ + 
| 1001 | SMITH | m 1 20 | CLERK 1 800 | 2005-11-121 
| 1002 | ALLEN | f 1 30 | SALESMRAN | 1600" | 2003=05=12 | 
| 1008 | SCOTT | m 1 20 | ANALYST | 3000 1 2003=05=12 | 
| 1011 | ADAMS | m 1 20 | CLERK 1 1100 | 1999-10-051 
+ 一 -一 一- + 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 一 +-------- 一 +---------- +--------- +------------ 十 


4 rows in set (0.00 sec) 

在 employee 表 中 ， 查 询 到 目前 为 止 ， 工 龄 大 于 等 于 15 年 的 员工 信息 。 

SELECT * FROM employee where YEAR(CURDATE()) -YERAR (hireDate) >= 15; 
执行 过 程 如 下 : 

mysql> SELECT * FROM employee where YEAR(CURDATE()) -YEAR(hireDate) >= 15; 


+ 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 +---------- +--------- +---------- +---------- +----------- 十 
| e_no | e_name | e gender | dept no | e_job | e_salary | hireDate | 


| 1004 | JONES | m || 20 | MANAGER | SEED 
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| 1005 | MARTIN | m 1 30 | SALESMAN | L250 | 2001=06=12 | 
| 1006 | BLAKE | f 1 30 | MANAGER | 2850J 2997=02=15 | 
L009 | KING Ef 1 10 | PRESIDENT | 5000 11995=01-01 | 
| 1010 | TURNER | f 1 30 | SALESMAN | L500 1997=10=12 1 
| 1011 | ADAMS | m 1 20 | CLERK 1 00 IT999=T0=05 
:二 二 一 7 二 二 三 一 一 二 一 一 二 二 一 一 二 一 二 二 二 二 三 二 = 二 1 一 = 一 一 一 一 一 一 一 一 一 二 二 一 一 二 二 一 一 一 一 + 


6 rows in set (0.01 sec) 


17.6 ”高 手 私房 菜 


技巧 1: 插入 记录 时 可 以 不 指定 字段 名 称 吗 ? 

不 管 使 用 哪 种 INSERT 语法 ， 都 必须 给 出 VALUES 的 正确 数目 。 如 果 提 供 字 段 名 ， 则 不 必 给 
每 个 字段 提供 一 个 值 ; 如 果 不 提供 字段 名 ， 则 必须 为 每 个 字段 提供 一 个 值 ， 否 则 将 产生 一 条 错误 消 
息 。 如 果 要 在 INSERT 操作 中 省 略 某 些 字段 ， 这 些 字段 需要 满足 一 定 条 件 ， 该 列 定义 为 允许 空 值 ; 
或 者 表 定 义 时 给 出 默认 值 ， 如 果 不 给 出 值 ， 将 使 用 默认 值 。 

技巧 2: 更 新 或 者 删除 表 时 必须 指定 WHERE 子 句 吗 ? 

在 前 面 章 节 中 可 以 看 到 ， 所 有 的 UPDATE 和 DELETE 语句 全 都 在 WHERE 子 句 指定 了 条 件 。 如 果 省 
略 WHERE 子 句 ， 则 UPDATE 或 DELETE 将 被 应 用 到 表 中 所 有 的 行 。 因 此 ， 除 非 确实 打算 更 新 或 者 删除 
所 有 记录 ， 否 则 绝对 要 注意 使 用 不 带 WHERE 子 句 的 UPDATE 或 DELETE 语句 。 建 议 在 对 表 进 行 更 新 和 
删除 操作 之 前 ， 使 用 SELECT 语句 确认 需要 删除 的 记录 ， 以 免 造 成 无 法 挽回 的 结果 。 

技巧 3: 什么 时 候 使 用 引号 ? 

在 查询 的 时 候 ， 会 看 到 在 WHERE 子 句 中 使 用 条 件 ， 有 的 值 加 上 了 单 引号 ， 而 有 的 值 未 加 。 
单 引号 用 来 限定 字符 串 ， 如 果 将 值 与 字符 串 类 型 列 进行 比较 ， 则 需要 限定 引号 ,用 来 与 数值 进行 比 
较 的 值 不 需要 用 引号 。 

技巧 4: 为 什么 使 用 通配符 格式 正确 ， 却 没有 查找 出 符合 条 件 的 记录 ? 

MySQL 中 存储 字符 串 数据 时 ， 可 能 会 不 小 心 把 两 端 带 有 空格 的 字符 串 保存 到 记录 中 ， 而 在 查 
看 表 中 记录 时 ，MySQL 不 能 明确 地 显示 空格 ， 数 据 库 操作 者 不 能 直观 地 确定 字符 串 两 端 是 否 有 空 
格 ， 例 如 ， 使 用 LIKE '%e' 匹配 以 字母 e 结尾 的 水 果 的 名 称 ， 如 果 字 母 e 后 面 多 了 一 个 空格 。 则 
LIKE 语句 不 能 将 该 记录 查找 出 来 。 解 决 的 方法 是 使 用 TRIM 函数 ， 将 字符 串 两 端的 空格 删除 之 后 
再 进行 匹配 。 


17.7 ”经 典 习题 


创建 数据 表 pet， 并 对 表 进 行 插 入 、 更 新 与 删除 操作 ，pet 表 结构 如 表 17-6 所 示 。 


(1) 首先 创建 数据 表 pet， 使 用 不 同 的 方法 将 表 17-7 中 的 记录 插入 到 pet 表 中 。 
(2) 使 用 UPDATE 语句 将 名 称 为 Fang 的 狗 的 主人 改 为 Kevin。 
(3) 将 没有 主人 的 宠物 的 owner 字段 值 都 改 为 Duck。 
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(4) 删除 已 经 死亡 的 宠物 记录 。 
(5) 删除 所 有 表 中 的 记录 。 





表 17-6 ”pet 表 结构 
字段 说 明 数据 类 型 E33 


[name | 宠物 % 称 |VARCHARCO | 五 | 看 


[species [种 类 [VARCHARCO | 奋 
[se | 


CHARO) 


符 


name owner Species 


re 
rr rr rs Ps rm mr 
[Bay [No tm To nu | 
[Fmg lBemmy lt mm ja nu | 
[Bowser [Diane lim mm am lm | 
[omy lx lu ls ln | 





第 18 章 数据 库 的 备份 与 还 原 


尽管 采取 了 一 些 管理 措施 来 保证 数据 库 的 安全 ， 但 是 不 确定 的 意外 情况 总 是 有 可 能 造成 数据 
的 损失 , 例如 意外 的 停电 、 管理 员 不 小 心 的 操作 失误 都 可 能 会 造成 数据 的 丢失 。 保证 数据 安全 的 最 
重要 的 一 个 措施 是 确保 对 数据 进行 定期 备份 。 如 果 数 据 库 中 的 数据 丢失 或 者 出 现 错误 , 可 以 使 用 备 
份 的 数据 进行 恢复 ， 这 样 就 尽 可 能 地 降低 了 意外 原因 导致 的 损失 。MySQL 提供 了 多 种 方法 对 数据 
进行 备份 和 恢复 。 本 章 将 介绍 数据 备份 、 数 据 恢复 、 数 据 迁 移 和 数据 导入 导出 的 相关 知识 。 
本 章 学 习 目标 

@ 了解 什么 是 数据 备份 
掌握 各 种 数据 备份 的 方法 
掌握 各 种 数据 恢复 的 方法 
掌握 数据 库 迁 移 的 方法 
掌握 表 的 导入 和 导出 方法 
熟练 掌握 综合 案例 中 数据 备份 与 恢复 的 方法 和 技巧 


18.1 数据 备份 


数据 备份 是 数据 库 管 理 员 非 常 重要 的 工作 之 一 。 系 统 意外 崩溃 或 者 硬件 的 损坏 都 可 能 导致 数 
据 库 的 丢失 ， 因 此 MySQL 管理 员 应 该 定期 地 备份 数据 库 ， 使 得 在 意外 情况 发 生 时 ， 尽 可 能 减少 损 
失 。 本 节 将 介绍 数据 备份 的 3 种 方法 。 

18.1.1 ”使 用 MySQLdump 命令 备份 

MySQLdump 是 MySQL 提供 的 一 个 非常 有 用 的 数据 库 备份 工具 。MySQLdump 命令 执行 时 ， 
可 以 将 数据 库 备 份 成 一 个 文本 文件 ， 该 文件 中 实际 上 包含 了 多 个 CREATE 和 INSERT 语句 ， 使 用 
这 些 语 句 可 以 重新 创建 表 和 插入 数据 。 

MySQLdump 备份 数据 库 语句 的 基本 语法 格式 如 下 : 

mysqldump -uuser -hhost -ppassword dbname[tbname, [tbname...]]> filename.sdql 

user 表示 用 户 名 称 ; host 表示 登录 用 户 的 主机 名 称 ; password 为 登录 密码 ; dbname 为 需要 备 
份 的 数据 库 名 称 ; tbname 为 dbname 数据 库 中 需要 备份 的 数据 表 ， 可 以 指定 多 个 需要 备份 的 表 ; 右 
篆 头 符号 “>” 告诉 MySQLdump 将 备份 数据 表 的 定义 和 数据 写 入 备份 文件 ; filename.sql 为 备份 文 
件 的 名 称 。 

1. 使 用 MySQLdump 备份 单个 数据 库 中 的 所 有 表 

【 例 18.1】 使 用 MySQLdump 命令 备份 数据 库 中 的 所 有 表 ， 执 行 过 程 如 下 : 
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为 了 更 好 理解 MySQLdump 工具 如 何 了 


[ 作 ， 本 章 给 出 一 个 完整 的 数据 库 例 子 。 首 先 登 录 


MySQL， 按 下 面 数据 库 结构 创建 booksDB 数据 库 和 各 个 表 ， 并 插入 数据 记录 。 数 据 库 和 表 定 义 如 


下 : 


CREATE DATABASE booksDB; 
use booksDB; 


CREATE TABLE books 

( 

bk id INT NOT NULL PRIMARY KEY, 
bk title VARCHAR(50) NOT NULL, 
copyright YEAR NOT NULL 

A 

INSERT INTO books 

VALUES (11078, 
(11033, 'Study Html', 
(11035, 'How to use php', 
(TION 
(11028, 
(11069, 
(TITO2 6 
(11041, 


2011)， 
2003), 


'Learning C++', 2005), 
'MySQL professional', 
'Guide to MySQL 5.7', 
'Inside VC++', 2011); 


CREATE TABLE authors 

( 

auth_id INT NOT NULL PRIMARY KEY, 
auth name VARCHAR(20), 

auth gender CHAR(1) 

); 
INSERT 
VALUES 
(LOO 
(1003， 
(1004, 
(OTs 
(LOTS 
(1013, 
(1014, 
(1015, 


INTO authors 

(1001, "WriterX'" 
'WriterA' ,'f'"'), 
'WriterB’' ,'m'), 
"WriterC" Gf"), 
WeltorD En) 
'WriterE' ,'m'), 
'WriterF"' ,'m'), 
"WriterG® rf"), 
"WriterH’ ,'f"'); 


人 


CREATE 
( 

auth id INT NOT NULL, 

bk id INT NOT NULL, 

PRIMARY KEY (auth id, bk id), 


TABLE authorbook 





'Learning MySQL', 2010), 


"Teach yourself javascript', 2005), 


2009)， 
2008)， 
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FOREIGN KEY (auth id) REFERENCES authors (auth id)， 
FOREIGN KEY (bk id) REFERENCES books (bk id) 
ji 


INSERT INTO authorbook 

VALUES (1001, 11033), (1002, 11035), (1003, 11072), (1004, 11028), 

(1011, 11078), (1012, 11026), (1012, 11041), (1014, 11069); 

完成 数据 插入 后 打开 操作 系统 命令 行 输入 窗口 ， 输 入 备份 命令 如 下 : 

C:\ >mysqldump -u root -p booksdb > C:/backup/booksdb 20160301.sql 

Enter password: ** 

输入 密码 之 后 ，MySQL 便 对 数据 库 进行 了 备份 ， 在 C:\backup 文件 夹 下 面 查看 刚才 备份 过 的 
文件 ， 使 用 文本 查看 器 打开 文件 可 以 看 到 其 部 分 文件 内 容 大 致 如 下 : 

-- MySQL dump 10.13 Distrib 5.7.10, for Win32 (x86) 














-- Host: localhost Database: booksDB 


/*!140101 SET @OLD CHARACTER SET CLIENT=@@CHARACTER SET CLIENT */; 
/*!140101 SET @OLD CHARACTER SET RESULTS=@@CHARACTER SET RESULTS */; 
/*!140101 SET @OLD COLLATION CONNECTION=Q@@COLLATION CONNECTION */; 
/*!40101 SET NAMES utf8 */; 

/*!40103 SET @OLD TIME ZONE=@Q@TIME ZONE */; 

/*!40103 SET TIME ZONE='+00:00' */; 

/*!140014 SET @OLD UNIQUE CHECKS=@@UNIQUE CHECKS, UNIQUE CHECKS=0 */; 
/*!40014 SET @OLD FOREIGN KEY CHECKS=@@FOREIGN KEY CHECKS, FOREIGN KEY_ 
CHECKS=0 */; 

/*!140101 SET @OLD SQL MODE=@@SQL MODE, SQL MODE= 
'NO_AUTO_VALUE ON ZERO' */; 

/*!140111 SET @OLD SQL NOTES=@@SQL NOTES, SQL NOTES=0 */; 


-- Table structure for table ‘authorbook. 


DROP TABLE IF EXISTS “authorbook ; 
/*!40101 SET @saved cs client = @@character set client */; 
/*!40101 SET character set client = utf8 */; 
CREATE TABLE ‘authorbook. ( 
‘auth id” int(11) NOT NULL, 
‘bk id” int(11) NOT NULL, 
PRIMARY KEY (‘auth id ，bk id`)， 
REY DIE Wf bralo 
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CONSTRAINT ‘authorbook ibfk 1 FOREIGN KEY (‘auth id`) 
REFERENCES ‘authors. (‘auth id'`)， 
CONSTRAINT ‘authorbook ibfk 2° FOREIGN KEY (‘bk id`) 
REFERENCES ‘books. (‘bk id`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 
/*!40101 SET character set client = @saved cs client */; 


-- Dumping data for table “authorbook. 


LOCK TABLES ‘authorbook. WRITE; 

/*!140000 ALTER TABLE “authorbook ”DISRBLE KEYS */; 

INSERT INTO ‘authorbook. VALUES (1012,11026), (1004,11028), (1001,11033), 
(1002,11035), (1012, 11041), (1014,11069), (1003,11072), (1011,11078); 

/*!40000 ALTER TABLE “authorbook ”ENRBLE KEYS */; 

UNLOCK TABLES; 


… 省 略 部 分 内 容 
/x140103 SET TIME ZONE=@OLD TIME ZONE */; 


/*!40101 SET SQL MODE=@OLD SQL MODE hs 

/*!40014 SET FOREIGN KEY CHECKS=@OLD FOREIGN KEY CHECKS */; 
/*!40014 SET UNIQUE CHECKS=@OLD UNIQUE CHECKS */; 

/*!140101 SET CHARACTER SET CLIENT=Q@OLD CHARACTER SET CLIENT */; 
/*!40101 SET CHARACTER SET RESULTS=@OLD CHARACTER SET RESULTS */; 
/*!40101 SET COLLATION CONNECTION=@OLD COLLATION CONNECTION */; 
/*!40111 SET SQL NOTES=@OLD SQL NOTES * A 

-- Dump completed on 2011-08-18 10:44:08 


可 以 看 到 ， 备 份 文件 包含 了 一 些 信息 ， 文 件 开 头 首先 表明 了 备份 文件 使 用 的 MySQLdump 工 
具 的 版 本 号 ; 然后 是 备份 账户 的 名 称 和 主机 信息 ， 以 及 备份 的 数据 库 的 名 称 ， 最 后 是 MySQL 服务 
器 的 版 本 号 ， 在 这 里 为 5.7.10。 

备份 文件 接 下 来 的 部 分 是 一 些 SET 语句 ， 这 些 语 句 将 一 些 系统 变量 值 赋 给 用 户 定义 变量 ， 以 
确保 被 恢复 的 数据 库 的 系统 变量 和 原来 备份 时 的 变量 相同 ， 例 如 : 

/*!140101 SET @OLD CHARACTER SET CLIENT=@@CHARACTER SET_ CLIENT 这 不 


该 SET 语句 将 当前 系统 变量 character set_client 的 值 赋 给 用 户 定义 变量 @old_character_ 
set_client。 其 他 变量 与 此 类 似 。 
备份 文件 的 最 后 几 行 MySQL 使 用 SET 语句 恢复 服务 器 系统 变量 原来 的 值 ， 例 如 : 


/*!140101 SET CHARACTER SET CLIENT=@OLD CHARACTER SET CLIENT */; 


该 语句 将 用 户 定义 的 变量 @old_character set_client 中 保存 的 值 赋 给 实际 的 系统 变量 
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character_set_client。 

备份 文件 中 的 “--” 字 符 开头 的 行为 注释 语句 ， 以 “/*!” 开 头 、“*/” 结 尾 的 语句 为 可 执行 的 
MySQL 注释 ， 这 些 语 句 可 以 被 MySQL 执行 ， 但 在 其 他 数据 库 管理 系统 将 被 作为 注释 忽略 ， 这 可 
以 提高 数据 库 的 可 移植 性 。 

另外 注意 到 ,备份 文件 开始 的 一 些 语句 以 数字 开头 ,这些 数字 代表 了 MySQL 版 本 号 ,该 数字 
告诉 我 们 ， 这 些 语句 只 有 在 指定 的 MySQL 版 本 或 者 比 该 版 本 高 的 情况 下 才能 执行 。 例 如 40101， 
表明 这 些 语句 只 有 在 MySQL 版 本 号 为 4.01.01 或 者 更 高 的 条 件 下 才 可 以 被 执行 。 

2. 使 用 MySQLdump 备份 数据 库 中 的 某 个 表 

在 前 面 MySQLdump 语法 中 介绍 过 , MySQLdump 还 可 以 备份 数据 中 的 某 个 表 , 其 语法 格式 为 : 

mysqldump -u user -h host -p dbname [tbname, [tbname...]] > filename.sql 

tbname 表示 数据 库 中 的 表 名 ， 多 个 表 名 之 间 用 空格 隔 开 。 

备份 表 和 备份 数据 库 中 所 有 表 的 语句 中 不 同 的 地 方 在 于 ,要 在 数据 库 名 称 dbname 之 后 指定 需 
要 备份 的 表 名 称 。 

【 例 18.2】 备 份 booksDB 数据 库 中 的 books 表 ， 输 入 语句 如 下 : 

mysqldump -u root -p booksDB books > C:/backup/books 20160301.sql 

该 语句 创建 名 称 为 books_20160301.sql 的 备份 文件 ， 文 件 中 包含 了 前 面 介绍 的 SET 语句 等 内 
容 ， 不 同 的 是 ， 该 文件 只 包含 books 表 的 CREATE 和 INSERT 语句 。 


3. 使 用 MySQLdump 备份 多 个 数据 库 


如 果 要 使 用 MySQLdump 备份 多 个 数据 库 , 需要 使 用 --databases 参数 。 备份 多 个 数据 库 的 语句 
格式 如 下 : 


mysqldump -uuser -h host -p --databases [dbname，[dbname...]] > filename.sdql 
使 用 --databases 参数 之 后 , 必须 指定 至 少 一 个 数据 库 的 名 称 , 多 个 数据 库 名 称 之 间 用 空格 隔 开 。 
【 例 18.3】 使 用 MySQLdump 备份 booksDB 和 test 数据 库 ， 输 入 语句 如 下 : 


mysqldump -u root -p --databases booksDB test> C:\backup\books testDB_ 
20160301.sql 


该 语句 创建 名 称 为 books_testDB_20160301.sql 的 备份 文件 ， 文 件 中 包含 了 创建 两 个 数据 库 
booksDB 和 test_db 所 必须 的 所 有 语句 。 
另外 ， 使 用 --all-databases 参数 可 以 备份 系统 中 所 有 的 数据 库 ， 语 句 如 下 : 


mysqldump -u user -h host -p --all-databases > filename.sql 
使 用 参数 --all-databases 时 ， 不 需要 指定 数据 库 名 称 。 


【 例 18.4】 使 用 MySQLdump 备份 服务 器 中 的 所 有 数据 库 ， 输 入 语句 如 下 : 
mysqldump -u root -p --all-databases > C:/backup/alldbinMySQL.sql 
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该 语句 创建 名 称 为 alldbinMySQL.sql 的 备份 文件 ， 文 件 中 包含 了 对 系统 中 所 有 数据 库 的 备份 





C7 如 果 在 服务 器 上 进行 备份 ， 并 且 表 均 为 MyISAM 表 ， 应 考虑 使 用 MySQLhotcopy， 因 
提示 为 可 以 更 快 地 进行 备份 和 恢复 。 


MySQLdump 还 有 一 些 其 他 选项 可 以 用 来 制定 备份 过 程 ， 例 如 --opt 选项 ， 该 选项 将 打开 
--quick 、--add-locks、--extended-insert 等 多 个 选项 。 使 用 --opt 选项 可 以 提供 最 快速 的 数据 库 转 储 。 


MySQLdump 其 他 常用 选项 如 下 : 


®@  --add-drop-database: 在 每 个 CREATE DATABASE 语句 前 添加 DROP DATABASE 语句 。 

®@  --add-drop-tables: 在 每 个 CREATE TABLE 语句 前 添加 DROP TABLE 语句 。 

@  --add-locking: 用 LOCK TABLES 和 UNLOCK TABLES 语句 引用 每 个 表 转 储 。 重 载 转 储 
文件 时 插入 得 更 快 。 

@ -all--database，-A: 转 储 所 有 数据 库 中 的 所 有 表 。 与 使 用 --database 选项 相同 ， 在 命令 行 
中 命名 所 有 数据 库 。 

®@ 。 --comments[=0|1]: 如 果 设 置 为 0， 禁止 转 储 文件 中 的 其 他 信息 ， 例 如 程序 版 本 、 服 务 器 版 本 
和 主机 。--skip-comments 与 -comments=0 的 结果 相同 。 默 认 值 为 1， 即 包括 额外 信息 。 

@  --compact: 产生 少量 输出。 该 选项 禁用 注释 并 启用 --skip-add-drop-tables、--no-set-names、 
--skip-disable-keys 和 --skip-add-locking 选项 。 

@  --compatible=name: 产生 与 其 他 数据 库 系统 或 旧 的 MySQL 服务 器 更 兼容 的 输出 。 值 可 以 

为 ansi、 MySQL323、MySQL40、postgresql、 oracle、 mssql、 db2、maxdb、 no_key_options、 

no_tables_options 或 者 no_field_options。 

--complete-insert，-c: 使 用 包括 列 名 的 完整 的 INSERT 语句 。 

---debug[=debug_options]，-# [debug_options]: 写 调 试 日 志 。 

--delete，-D: 导入 文本 文件 前 清空 表 。 

--default-character-set=charset: 使 用 charsetas 默认 字符 集 。 如 果 没 有 指定 ，MySQLdump 

使 用 utf8。 

@  --delete-master-logs: 在 主 复 制服 务 器 上 ， 完 成 转 储 操作 后 删除 二 进 制 日 志 。 该 选项 自动 
启用 -master-data。 

@ 。 --extended-insert，-e: 使 用 包括 几 个 VALUES 列表 的 多 行 INSERT 语法 。 这 样 使 转 储 文 
件 更 小 ， 重 载 文件 时 可 以 加 速 插入 。 

@  --flush-logs，-F: 开始 转 储 前 刷新 MySQL 服务 器 日 志文 件 。 该 选项 要 求 RELOAD 权限 。 

@  --forcee，-f: 在 表 转 储 过 程 中 ， 即 使 出 现 SQL 错误 也 继续 。 

®@ 。 --lock-all-tables，-x: 对 所 有 数据 库 中 的 所 有 表 加 锁 。 在 整体 转 储 过 程 中 通过 全 局 锁定 来 
实现 。 该 选项 自动 关闭 --single-transaction 和 --lock-tables。 

@  --lock-tables，-l: 开始 转 储 前 锁定 所 有 表 。 用 READ LOCAL 锁定 表 以 允许 并 行 插入 
MyISAM 表 。 对 于 事务 表 ( 例如 InnoDB 和 BDB ), --single-transaction 是 一 个 更 好 的 选项 ， 
因为 它 根 本 不 需要 锁定 表 。 

®@  --no-create-db，-n: 该 选项 禁用 CREATE DATABASE /*!32312 IF NOT EXISTS*/ db_name 
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语句 ， 如 果 给 出 --database 或 -all--database 选项 ， 则 包含 到 输出 中 。 

®@ -no-create-info，-t: 只 导出 数据 ， 而 不 添加 CREATE TABLE 语句 。 

--no-data，-d: 不 写 表 的 任何 行 信息 ， 只 转 储 表 的 结构 。 

@  --opt: 该 选项 是 速记 ， 等 同 于 指定 --add-drop-tables--add-locking 、--create-option 、 
--disable-keys--extended-insert、--lock-tables-quick 和 --set-charset。 它 可 以 快速 进行 转 储 操 
作 并 产生 一 个 能 很 快 装 入 MySQL 服务 器 的 转 储 文件 。 该 选项 默认 开启 ， 但 可 以 用 
--Skip-opt 禁用 。 要 想 禁 用 使 用 -opt 启用 的 选项 ， 可 以 使 用 --skip 形式 ， 例 如 
--skip-add-drop-tables 或 --skip-quick。 

®@  --password[=password]，-p[password]: 当 连 接 服务 器 时 使 用 的 密码 。 如 果 使 用 短 选 项 形式 

(-p)， 选 项 和 密码 之 间 不 能 有 空格 。 如 果 在 命令 行 中 --password 或 -p 选项 后 面 没有 密码 

值 ， 则 提示 输入 一 个 密码 。 

@  --port=port num，-Pport_num: 用 于 连接 的 TCP/IP 端口 号 。 

--protocol={TCP | SOCKET | PIPE | MEMORY}: 使 用 的 连接 协议 。 

®@ 。 --replace，-r --replace 和 一 ignore: 控制 替换 或 复制 唯一 键 值 已 有 记录 的 输入 记录 的 处 理 。 

如 果 指 定 --replace， 新 行 蔡 换 有 相同 的 唯一 键 值 的 已 有 行 ; 如 果 指 定 --ignore， 复 制 已 有 的 

唯一 键 值 的 输入 行 被 跳 过 。 如 果 不 指定 这 两 个 选项 ， 当 发 现 一 个 复制 键 值 时 会 出 现 一 个 

错误 ， 并 且 忽视 文本 文件 的 剩余 部 分 。 

--silent，-s: 沉默 模式 。 只 有 出 现 错误 时 才 输 出 。 

--socket=path，-S path: 当 连 接 localhost 时 使 用 的 套 接 字 文 件 ( 为 默认 主机 )。 

--Uuser=user_name，-uuser_name: 当 连 接 服务 器 时 MySQL 使 用 的 用 户 名 。 

--verbose，-V: 宛 长 模式 。 打印 出 程序 操作 的 详细 信息 。 

--version，-V: 显示 版 本 信息 并 退出 。 

--xml，-X: 产生 XML 输出 。 


MySQLdump 提供 许多 选项 ,包括 用 于 调试 和 压缩 的 ,在 这 里 只 是 列举 最 有 用 的 。 运 行 帮助 命 
令 MySQLdump --help， 可 以 获得 特定 版 本 的 完整 选项 列表 。 


C9 如 果 运行 MySQLdump 没有 --quick 或 -opt 选项, MySQLdump 在 转 储 结果 前 将 整个 结 

< 果 集 装 入 内 存 。 如 果 转 储 大 数据 库 ， 可 能 会 出 现 问题 。 该 选项 默认 启用 ， 但 可 以 用 

不  --skip-opt 禁用 。 如 果 使 用 最 新 版 本 的 MySQLdump 程序 备份 数据 ， 并 用 于 恢复 到 比较 
旧版 本 的 MySQL 服务 器 中 ， 则 不 要 使 用 --opt 或 -e 选项 。 


18.1.2 直接 复制 整个 数据 库 目 录 


因为 MySQL 表 保 存 为 文件 方式 ， 所 以 可 以 直接 复制 MySQL 数据 库 的 存储 目录 及 文件 进行 备 
份 。MySQL 的 数据 库 目录 位 置 不 一 定 相同 , 在 Windows 平台 下 ，MySQL 5.7 存放 数据 库 的 目录 通 
常 默认 为 C:\Documents and Settings\All Users\Application Data\MySQL\MYySQL Server 5.7\data 或 者 
其 他 用 户 自 定义 目录 ; 在 Linux 平台 下 ， 数 据 库 目 录 位 置 通常 为 /var/lib/MySQL/， 不 同 Linux 版 本 
下 目录 会 有 不 同 ， 读 者 应 在 自己 使 用 的 平台 下 查找 该 目录 。 

这 是 一 种 简单 、 快 速 、 有 效 的 备份 方式 。 要 想 保持 备份 的 一 致 性 ， 备 份 前 需要 对 相关 表 执 行 
LOCK TABLES 操作 ， 然 后 对 表 执行 FLUSH TABLES。 这 样 当 复制 数据 库 目 录 中 的 文件 时 ， 人 允许 
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其 他 客户 继续 查询 表 .。 需 要 FLUSH TABLES 语句 来 确保 开始 备份 前 将 所 有 激活 的 索引 页 写 入 硬盘 。 
当然 ， 也 可 以 停止 MySQL 服务 再 进行 备份 操作 。 

这 种 方法 虽然 简单 ， 但 并 不 是 最 好 的 方法 。 因 为 这 种 方法 对 InnoDB 存储 引擎 的 表 不 适用 。 使 
用 这 种 方法 备份 的 数据 最 好 恢复 到 相同 版 本 的 服务 器 中 ， 不 同 的 版 本 可 能 不 兼容 。 


C7 在 MySQL 版 本 号 中 ， 第 一 个 数字 表示 主 版 本 号 ， 主 版 本 号 相同 的 MySQL 数据 库 文 
件 格式 相同 。 


不 


18.1.3 ”使 用 MySQLhotcopy 工具 快速 备份 
MySQLhotcopy 是 一 个 Perl 脚本 ， 最 初 由 Tim Bunce 编写 并 提供 。 它 使 用 LOCK TABLES、 
FLUSH TABLES 和 cp 或 scp 来 快速 备份 数据 库 。 它 是 备份 数据 库 或 单个 表 的 最 快 的 途径 ,但 它 只 
能 运行 在 数据 库 目 录 所 在 的 机 器 上 ， 并 且 只 能 备份 MyISAM 类 型 的 表 。MySQLhotcopy 在 Unix 系 
统 中 运行 。 
MySQLhotcopy 命令 语法 格式 如 下 : 
mysqlhotcopy db name 1, ... db name n /path/to/new directory 
db_name_1,.….,db_name_n 分 别 为 需要 备份 的 数据 库 的 名 称 ，/path/to/new_directory 指定 备份 文 
件 目 录 。 
【 例 18.5】 使 用 MySQLhotcopy 备份 test 数据 库 到 /usr/backup 目录 下 ， 输 入 语句 如 下 : 
mysqlhotcopy -u root -p test /usr/backup 
要 想 执行 MySQLhotcopy, 必须 可 以 访问 备份 的 表 文 件 ,具有 那些 表 的 SELECT 权限 .RELOAD 
权限 以便 能 够 执行 FLUSH TABLES) 和 LOCK TABLES 权限 。 


MySQLhotcopy 只 是 将 表 所 在 的 目录 复制 到 另 一 个 位 置 ， 只 能 用 于 备份 MyISAM 和 
ARCHIVE 表 . 备份 InnoDB 类 型 的 数据 表 时 会 出 现 错误 信息 。 由 于 它 复 制 本 地 格式 的 
提 示 。 文件 故 也 不 能 移植 到 其 他 硬件 或 操作 系统 下 。 


18.2 ”数据 恢复 


管理 人 员 操 作 的 失误 、 计 算 机 故障 以 及 其 他 意外 情况 ， 都 会 导致 数据 的 丢失 和 破坏 。 当 数据 
丢失 或 意外 破坏 时 ,可 以 通过 恢复 已 经 备份 的 数据 尽量 减少 数据 丢失 和 破坏 造成 的 损失 。 本 节 将 介 
绍 数据 恢复 的 方法 。 
18.2.1 使 用 MySQL 命令 恢复 

对 于 已 经 备份 的 包含 CREATE、INSERT 语句 的 文本 文件 ， 可 以 使 用 MySQL 命令 导入 到 数据 
库 中 。 本 小 节 将 介绍 MySQL 命令 导入 sql 文件 的 方法 。 

备份 的 sql 文件 中 包含 CREATE、INSERT 语句 (有 时 也 会 有 DROP 语句 ) 。MySQL 命令 可 
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以 直接 执行 文件 中 的 这 些 语句 。 其 语法 如 下 : 


mysql -u user -p [dbname] < filename.sqgl 


user 是 执行 backup.sql 中 语句 的 用 户 名 ; -p 表示 输入 用 户 密码 ; dbname 是 数据 库 名 。 如 果 
filename.sql 文件 为 MySQLdump 工具 创建 的 包含 创建 数据 库 语 句 的 文件 ， 执 行 的 时 候 不 需要 指定 
数据 库 名 。 

【 例 18.6】 使 用 MySQL 命令 将 C:\backup\booksdb 20160301.sql 文件 中 的 备份 导入 到 数据 库 
中 ， 输 入 语句 如 下 : 

mysql -u root -p booksDB < C:/backup/booksdb 20160301.sql 


执行 该 语句 前 ， 必 须 先 在 MySQL 服务 器 中 创建 booksDB 数据 库 ， 如 果 不 存在 恢复 过 程 将 会 
出 错 。 命 令 执行 成 功 之 后 booksdb 20160301.sql 文件 中 的 语句 就 会 在 指定 的 数据 库 中 恢复 以 前 的 
表 。 

如 果 已 经 登录 MySQL 服务 器 ， 还 可 以 使 用 source 命令 导入 sql 文件 。source 语句 语法 如 下 : 


source filename 


【 例 18.7】 使 用 root 用 户 登 录 到 服务 器 ， 然 后 使 用 source 导入 本 地 的 备份 文件 
booksdb_20160301.sql， 输 入 语句 如 下 : 
- -选择 要 恢复 到 的 数据 库 
mysql> use booksDB; 
Database changed 








-- 使 用 source 命令 导入 备份 文件 
mysql> source C:\backup\booksDB 20160301.sql 


命令 执行 后 ， 会 列 出 备份 文件 booksDB_20160301.sql 中 每 一 条 语句 的 执行 结果 。source 命令 
执行 成 功 后 ，booksDB_20160301.sql 中 的 语句 会 全 部 导入 到 现 有 数据 库 中 。 


C7 执行 source 命令 前 , 必须 使 用 use 语句 选择 数据 库 . 不 然 , 恢复 过 程 中 会 出 现 “ERROR 
提示 1046 (3D000): No database selected” 的 错误 。 
示 


18.2.2 直接 复制 到 数据 库 目 录 


如 果 数 据 库 通过 复制 数据 库 文件 备份 , 可 以 直接 复制 备份 的 文件 到 MySQL 数据 目录 下 实现 恢 
复 。 通 过 这 种 方式 恢复 时 ， 必 须 保 存 备 份 数据 的 数据 库 和 待 恢复 的 数据 库 服务 器 的 主 版 本 号 相同 。 
而 且 这 种 方式 只 对 MyISAM 引擎 的 表 有 效 ， 对 于 InnoDB 引擎 的 表 不 可 用 。 

执行 恢复 以 前 关闭 MySQL 服务 , 将 备份 的 文件 或 目录 覆盖 MySQL 的 data 目录 , 启动 MySQL 
服务 。 对 于 Linux/Unix 操作 系统 来 说 , 复制 完 文件 需要 将 文件 的 用 户 和 组 更 改 为 MySQL 运行 的 用 
户 和 组 ， 通 常用 户 是 MySQL， 组 也 是 MySQL。 
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18.2.3 MySQLhotcopy 快速 恢复 


MySQLhotcopy 备份 后 的 文件 也 可 以 用 来 恢复 数据 库 ， 在 MySQL 服务 器 停止 运行 时 ， 将 备份 
的 数据 库 文件 复制 到 MySQL 存放 数据 的 位 置 (MySQL 的 data 文件 夹 ) ， 重 新 启动 MySQL 服务 
即 可 。 如 果 以 根 用 户 执行 该 操作 ， 必 须 指定 数据 库 文件 的 所 有 者 ， 输 入 语句 如 下 : 
chown -R mysql.mysql /var/lib/mysql/dbname 
【 例 18.8】 从 MySQLhotcopy 复制 的 备份 恢复 数据 库 ， 输 入 语句 如 下 : 
cp -R /usr/backup/test usr/local/mysql/data 


执行 完 该 语句 ， 重 启 服务 器 ，MySQL 将 恢复 到 备份 状态 。 


C0 如 果 需 要 恢复 的 数据 库 已 经 存在 ， 则 在 使 用 DROP 语句 删除 已 经 存在 的 数据 库 之 后 ， 
提示 恢复 才能 成 功 。 另 外 MySQL 不 同 版 本 之 间 必 须 兼容 ， 恢 复 之 后 的 数据 才 可 以 使 用 。 
人 \ 


18.3 ”数据库 迁 移 


数据 库 迁 移 就 是 把 数据 从 一 个 系统 移动 到 另 一 个 系统 上 。 数 据 迁 移 有 以 下 原因 : 
(1) 需要 安装 新 的 数据 库 服务 器 。 
(2) MySQL 版 本 更 新 。 
(3) 数据 库 管 理 系统 的 变更 (如 从 Microsoft SQL Server 迁移 到 MySQL) 。 

本 小 节 将 讲解 数据 库 迁 移 的 方法 。 

18.3.1 相同 版 本 的 MySQL 数据 库 之 间 的 迁移 

相同 版 本 的 MySQL 数据 库 之 间 的 迁移 就 是 在 主 版 本 号 相同 的 MySQL 数据 库 之 间 进行 数据 库 
移动 。 迁 移 过 程 其 实 就 是 在 源 数据 库 备 份 和 目标 数据 库 恢复 过 程 的 组 合 。 

在 讲解 数据 库 备 份 和 恢复 时 ， 已 经 知道 最 简单 的 方式 是 通过 复制 数据 库 文件 目录 ， 但 是 此 种 
方法 只 适用 于 MyISAM 引擎 的 表 。 而 对 于 InnoDB 表 ， 不 能 用 直接 复制 文件 的 方式 备份 数据 库 ， 
因此 最 常用 和 最 安全 的 方式 是 使 用 MySQLdump 命令 导出 数据 ， 然 后 在 目标 数据 库 服务 器 使 用 
MySQL 命令 导入 。 

【 例 18.9】 将 www.abc.com 主机 上 的 MySQL 数据 库 全 部 迁移 到 www.bcd.com 主机 上 。 在 
www.abc.com 主机 上 执行 的 命令 如 下 : 


mysqldump -h www.bac.com -uroot -ppassword dbname | 














mysql -h www.bcd.com -uroot -ppassword 


MySQLdump 导出 的 数据 直接 通过 管道 符 “ | ”， 传 给 MySQL 命令 导入 到 主机 www.bcd.com 
数据 库 中 , dbname 为 需要 迁移 的 数据 库 名 称 , 如 果 要 迁移 全 部 的 数据 库 , 可 使 用 参数 --all-databases 。 
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18.3.2 ”不同 版 本 的 MySQL 数据 库 之 间 的 迁移 


因为 数据 库 升 级 等 原因 ， 需 要 将 较 旧 版 本 MySQL 数据 库 中 的 数据 迁移 到 较 新 版 本 的 数据 库 
中 。MySQL 服务 器 升级 时 ， 需 要 先 停止 服务 ， 然 后 卸载 旧版 本 ， 并 安装 新 版 的 MySQL， 这 种 更 
新 方法 很 简单 ， 如 果 想 保留 旧版 本 中 的 用 户 访问 控制 信息 ， 则 需要 备份 MySQL 中 的 MySQL 数据 
库 ， 在 新 版 本 MySQL 安装 完成 之 后 ， 重 新 读 入 MySQL 备份 文件 中 的 信息 。 

旧版 本 与 新 版 本 的 MySQL 可 能 使 用 不 同 的 默认 字符 集 ， 例 如 MySQL 4.x 中 大 多 使 用 latin1 
作为 默认 字符 集 ， 而 MySQL 5.x 的 默认 字符 集 为 utft8。 如 果 数 据 库 中 有 中 文 数据 的 ， 迁 移 过 程 中 
需要 对 默认 字符 集 进行 修改 ， 不 然 可 能 无 法 正常 显示 结果 。 

新 版 本 会 对 旧版 本 有 一 定 兼容 性 。 从 旧版 本 的 MySQL 向 新 版 本 的 MySQL 迁移 时 ， 对 于 
MyISAM 引擎 的 表 ， 可 以 直接 复制 数据 库 文 件 ， 也 可 以 使 用 MySQLhotcopy 工具 、MySQLdump 
工具 。 对 于 InnoDB 引擎 的 表 ， 一 般 只 能 使 用 MySQLdump 将 数据 导出 。 然 后 使 用 MySQL 命令 导 
入 到 目标 服务 器 上 。 从 新 版 本 向 旧版 本 MySQL 迁移 数据 时 要 特别 小 心 ， 最 好 使 用 MySQLdump 命 
令 导 出 ， 然 后 导入 目标 数据 库 中 。 


18.3.3 不同 数 据 库 之 间 的 迁移 


不 同类 型 的 数据 库 之 间 的 迁移 ， 是 指 把 MySQL 的 数据 库 转 移 到 其 他 类 型 的 数据 库 ， 例 如 从 
MySQL 迁移 到 ORACLE， 从 ORACLE 迁移 到 MySQL， 从 MySQL 迁移 到 sqlserver 等 。 

迁移 之 前 ， 需 要 了 解 不 同 数据 库 的 架构 ， 比 较 它 们 之 间 的 差异 。 不 同 数据 库 中 定义 相同 类 型 
的 数据 的 关键 字 可 能 会 不 同 。 例 如 ，MySQL 中 日 期 字段 分 为 DATE 和 TIME 两 种 ， 而 ORACLE 
日 期 字段 只 有 DATE。 另 外 ， 数 据 库 厂 商 并 没有 完全 按照 SQL 标准 来 设计 数据 库 系统 ， 导 致 不 同 
的 数据 库 系统 的 SQL 语句 有 差别 。 例 如 ，MySQL 几乎 完全 支持 标准 SQL 语言 ， 而 Microsoft SQL 
Server 使 用 的 是 T-SQL 语言 ，T-SQL 中 有 一 些 非 标准 的 SQL 语句 ， 因 此 在 迁移 时 必须 对 这 些 语 名 
进行 语句 映射 处 理 。 

数据 库 迁 移 可 以 使 用 一 些 工具 , 例如 在 Windows 系统 下 , 可 以 使 用 MyODBC 实现 MySQL 和 
SQL Server 之 间 的 迁移 。MySQL 官方 提供 的 工具 MySQL Migration Toolkit 也 可 以 在 不 同 数据 库 间 
进行 数据 迁移 。 


























18.4 表 的 导出 和 导入 


有 时 会 需要 将 MySQL 数据 库 中 的 数据 导出 到 外 部 存储 文件 中 ，MySQL 数据 库 中 的 数据 可 以 
导出 成 sql 文本 文件 、xml 文件 或 者 html 文件 。 同 样 这 些 导 出 文件 也 可 以 导入 到 MySQL 数据 库 中 。 
本 小 节 将 介绍 数据 导出 和 导入 的 常用 方法 。 


18.4.1 使 用 SELECTI…INTO OUTFILE 导出 文本 文件 


MySQL 数据 库 导出 数据 时 ， 人 允许 使 用 包含 导出 定义 的 SELECT 语句 进行 数据 的 导出 操作 。 该 
文件 被 创建 到 服务 器 主机 上 ， 因 此 必须 拥有 文件 写 入 权限 (FILE 权限 ) ， 才 能 使 用 此 语法 。 
“SELECT...INTO OUTFILE 'filename'” 形 式 的 SELECT 语句 可 以 把 被 选择 的 行 写 入 一 个 文件 中 ， 
filename 不 能 是 一 个 已 经 存在 的 文件 。SELECT...INTO OUTFILE 语句 基本 格式 如 下 : 
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SELECT columnlist FROM table WHERE condition INTO OUTFILE ‘filename' 
[OPTIONS] 


=--OPTIONS 选项 
FIELDS TERMINATED BY "value'" 
FIELDS [OPTIONALLY] ENCLOSED BY 'value' 
FIELDS ESCAPED BY 'value' 
LINES STARTING BY 'value' 
LINES TERMINATED BY 'value' 


可 以 看 到 SELECT columnlist FROM table WHERE condition 为 一 个 查询 语句 , 查询 结果 返回 满 
足 指定 条 件 的 一 条 或 多 条 记录 ; INTO OUTFILE 语句 的 作用 就 是 把 前 面 SELECT 语句 查询 出 来 的 
结果 导出 到 名 称 为 “filename” 的 外 部 文件 中 。[OPTIONS] 为 可 选 参数 选项 ，OPTIONS 部 分 的 语法 
包括 FIELDS 和 LINES 子 句 ， 其 可 能 的 取 值 有 : 

@ FIELDS TERMINATED BY ‘value’: 设置 字段 之 间 的 分 隔 字 符 , 可 以 为 单个 或 多 个 字符 ， 

默认 情况 下 为 制 表 符 “At 。 
@ FIELDS [OPTIONALLY] ENCLOSED BY ‘value’: 设置 字段 的 包围 字符 ， 只 能 为 单个 字 
符 ， 如 果 使 用 了 OPTIONALLY 则 只 有 CHAR 和 VERCHAR 等 字符 数据 字段 被 包括 。 

@ ”FIELDS ESCAPED BY'value'”: 设置 如 何 写 入 或 读 取 特 殊 字符 ， 只 能 为 单个 字符 ， 即 设 
置 转 义 字符 ， 默 认 值 为 ^\。 

@ LINES STARTING BY ‘value”: 设置 每 行 数 据 开头 的 字符 ， 可 以 为 单个 或 多 个 字符 ， 默 
认 情 况 下 不 使 用 任何 字符 。 

@ LINES TERMINATED BY “value’: 设置 每 行 数据 结尾 的 字符 ， 可 以 为 单个 或 多 个 字符 ， 

默认 值 为 “\n? 。 

FIELDS 和 LINES 两 个 子 句 都 是 自选 的 ， 但 是 如 果 两 个 都 被 指定 了 ，FIELDS 必须 位 于 LINES 
的 前 面 。 

SELECT..INTO OUTFILE 语句 可 以 非常 快速 地 把 一 个 表 转 储 到 服务 器 上 。 如 果 想 要 在 服务 器 
主机 之 外 的 部 分 客户 主机 上 创建 结果 文件 ， 不 能 使 用 SELECT...INTO OUTFILE。 在 这 种 情况 下 ， 
应 该 在 客户 主机 上 使 用 比如 “MySQL -e "SELECT ..." > file_ name” 的 命令 来 生成 文件 。 

SELECT...INTO OUTFILE 是 LOAD DATA INFILE 的 补 语 。 用 于 语句 的 OPTIONS 部 分 的 语法 
包括 部 分 FIELDS 和 LINES 子 句 ， 这 些 子 句 与 LOAD DATA INFILE 语句 同时 使 用 。 

【 例 18.10】 使 用 SELECT...INTO OUTFILE 将 test 数据 库 中 的 person 表 中 的 记录 导出 到 文本 
文件 ， 输 入 命令 如 下 : 
SELECT * FROM test.person INTO OUTFILE "C:N\Person0 .txt"7 

由 于 指定 了 INTO OUTFILE 子 句 ，SELECT 将 查询 出 来 的 3 个 字段 的 值 保 存 到 Ci:\person0.txt 
文件 中 ， 打 开 文件 内 容 如 下 : 

和 1 Green 21 Lawyer 


2 Suse 22 dancer 
=| Mary 24 Musician 
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Willam 20 sports man 
Laura 25 “AN 
Evans 27 ”Secretary 
Dale 22 cook 
Edison 28 singer 
Harry 21 magician 

0 Harriet 19 pianist 


Poo aowm 心 


可 以 看 到 默认 情况 下 ，MySQL 使 用 制 表 符 “\t” 分 隔 不 同 的 字段 ， 字 段 没 有 被 其 他 字符 括 起 


来 。 另 外 ， 在 Windows 平台 下 ， 使 用 记事 本 打开 该 文件 ， 显 示 的 格式 与 这 里 并 不 相同 ， 这 是 





因为 


Windows 系统 下 回 车 换行 符 为 “\nn”， 默 认 换 行 符 为 “\n”， 因 此 会 在 person.txt 中 可 能 看 到 类 似 





黑色 方块 的 字符 ， 所 有 的 记录 也 会 在 同一 行 显示 。 
另外 ,注意 到 第 5 行 中 有 一 个 字段 值 为 “N”， 这 表示 该 字段 的 值 为 NULL。 默 认 情况 下 


， 如 


果 遇 到 NULL 值 ， 将 会 返回 “WN ”代表 空 值 ， 反 斜 线 ^\” 表 示 转 义 字符 ， 如 果 使 用 ESCAPED BY 


选项 ， 则 N 前 面 为 指定 的 转 义 字符 。 


【 例 18.11】 使 用 SELECT...INTO OUTFILE 将 test 数据 库 中 的 person 表 中 的 记录 导出 到 文本 
文件 ， 使 用 FIELDS 选项 和 LINES 选项 ， 要 求 字 段 之 间 使 用 逗号 “,” 间 隔 ， 所 有 字段 值 用 双 引 号 


括 起 来 ， 定 义 转 义 字符 为 单 引 号 “v”， 执 行 的 命令 如 下 : 
SELECT * FROM test.person INTO OUTFILE "C:\Personl .txt" 
FIELDS 
TERMINRTED BY ',' 
ENCLOSED BY '\"' 
ESCAPED BY '\'' 
LINES 
TERMINRTED BY '\r\n'; 


该 语句 将 把 person 表 中 所 有 记录 导入 到 C 盘 目 录 下 的 personl.txt 文本 文件 中 。 


FIELDS TERMINATED BY "表示 字 段 之 间 用 逗号 分 隔 。ENCLOSED BY \" 表 示 每 个 字段 用 双 
引号 括 起 来 .ESCAPED BY \" 表 示 将 系统 默认 的 转 义 字符 替换 为 单 引号 ,LINES TERMINATED BY 


"rin' 表 示 每 行 以 回 车 换行 符 结尾 ， 保 证 每 一 条 记录 占 一 行 。 
执行 成 功 后 ， 在 目录 C:\ 下 生成 一 个 personl txt 文件 ， 打 开 文件 内 容 如 下 : 


"1", "Green","21","Lawyer" 
"2","Suse", "22","dancer" 

"3" "Mary", "24", "Musician" 
mA" "Willam", "20", "sports man" 
FS "25"7 NY" 

"6", "Evans","27","secretary" 
wn npaleny 22 Coo 
"8","Edison", "28", "singer" 
"9", "Harry", "21", "magician" 
"10", "Harriet", "19", "pianist" 


可 以 看 到 ， 所 有 的 字段 值 都 被 双 引 号 包括 ; 第 5 条 记录 中 空 值 的 表示 形式 为 “N”， 即 使 用 单 
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引号 替换 了 反 和 斜 线 转 义 字符 。 


【 例 18.12】 使 用 SELECT...INTO OUTFILE 将 test 数据 库 中 的 person 表 中 的 记录 导出 到 文本 
文件 ， 使 用 LINES 选项 ， 要 求 每 行 记录 以 字符 串 “>” 开 始 ， 以 “<end>” 字 符 串 结尾 ， 执 行 的 命 


令 如 下 : 
SELECT * FROM test.person INTO OUTFILE "C:\person2.txt" 
LINES 
STARTING BY '>"' 
TERMINATED BY '<end>'; 


执行 成 功 后 ， 在 目录 C:\ 下 生成 一 个 person2.txt 文件 ， 打 开 文 件 内 容 如 下 : 


>1 Green 21 Lawyer <end>> 2 Suse 22 dancer <end>> 3 Mary 24 
Musician <end>> 4 Willam 20 sports man <end>> 5Laura 25 \N <end>> 6 
Evans 27 secretary <end>> 7 Dale 22 cook <end>> 8 Edison 28 


singer <end>> 9 Harry 21 magician <end>> 10 Harriet 19 pianist <end> 


可 以 看 到 ， 虽 然 将 所 有 的 字段 值 导出 到 文本 文件 中 ， 但 是 所 有 的 记录 没有 分 行 区 分 ， 出 现 这 
种 情况 是 因为 TERMINATED BY 选项 奉 换 了 系统 默认 的 “m” 换 行 符 ， 如 果 希 望 换行 显示 ， 则 需 


要 修改 导出 语句 ， 输 入 下 面 语句 : 


SELECT * FROM test.person INTO OUTFILE "C:\person2.txt" 
LINES 

STARTING BY '>' 

TERMINATED BY '<end>\r\n'; 


执行 完 语 句 之 后 ， 换 行 显示 每 条 记录 ， 结 果 如 下 : 


> 1 Green 21 Lawyer <end> 

> 2 Suse 22 dancer <end> 
> 3 Mary 24 Musician <end> 
> 4 Willam 20 sports man <end> 
> 5 Laura 25 \N <end> 

> 6 Evans 27 secretary <end> 

> 7 Dale 22 cook <end> 

> 8 Edison 28 singer <end> 

> 9 Harry 21 magician <end> 
> 10 Harriet 19 Pianist <end> 


18.4.2 ”使 用 MySQLdump 命令 导出 文本 文件 


除了 使 用 SELECT.… INTO OUTFILE 语句 导出 文本 文件 之 外 ， 还 可 以 使 用 MySQLdump 。 本 


章 开始 介绍 了 使 用 MySQLdump 备份 数据 库 , 该 了 





[ 具 不 仅 可 以 将 数据 导出 为 包含 CREATE INSERT 


的 sql 文件 ， 也 可 以 导出 为 纯 文 本 文件 。 
MySQLdump 创 妈 
数据 的 tablename.txt 文件 。MySQLdump 导出 文本 文件 的 基本 语法 格式 如 下 : 





一 个 包含 创建 表 的 CREATE TABLE 语句 的 tablename.sql 文件 和 一 个 包含 其 





数据 库 的 备份 与 还 原 第 18 章 





mysqldump -T path-u root -p dbname [tables] [OPTIONS] 


=--OPTIONS 选项 
--fields-terminated-by=value 
--fields-enclosed-by=value 
--fields-optionally-enclosed-by=value 
--fields-escaped-by=value 
--lines-terminated-by=value 


只 有 指定 了 -T 参数 才 可 以 导出 纯 文本 文件 ; path 表示 导出 数据 的 目录 ; tables 为 指定 要 导出 的 
表 名 称 ， 如 果 不 指定 ， 将 导出 数据 库 dbname 中 所 有 的 表 ; [OPTIONS] 为 可 选 参数 选项 ， 这 些 选 项 
需要 结合 -T 选项 使 用 。 使 用 OPTIONS 常见 的 取 值 有 : 


@  --fields-terminated-by=value: 设置 字段 之 间 的 分 隔 字 符 ， 可 以 为 单个 或 多 个 字符 ， 默 认 情 
况 下 为 制 表 符 At 。 

@  --fields-enclosed-by=value: 设置 字段 的 包围 字符 。 

@  --fields-optionally-enclosed-by=value: 设置 字段 的 包围 字符 ， 只 能 为 单个 字符 ， 只 能 包括 
CHAR 和 VERCHAR 等 字符 数据 字段 。 

®@  --fields-escaped-by=value: 控制 如 何 写 入 或 读 取 特殊 字符 ， 只 能 为 单个 字符 ， 即 设置 转 义 
字符 ， 默 认 值 为 反 斜 线 “\”。 

@  --lines-terminated-by=value: 设置 每 行 数据 结尾 的 字符 ， 可 以 为 单个 或 多 个 字符 ， 默 认 值 
光 


【分 与 SELECT.…INTO OUTFILE 语句 中 的 OPTIONS 各 个 参数 设置 不 同 , 这 里 OPTIONS 
提示 各 个 选项 等 号 后 面 的 value 值 不 要 用 引号 括 起 来 。 


【 例 18.13】 使 用 MySQLdump 将 test 数据 库 中 的 person 表 中 的 记录 导出 到 文本 文件 ， 执 行 的 
命令 如 下 : 


mysqldump -T C:\test person -u root-p 


语句 执行 成 功 , 系统 C 盘 目 录 下 面 将 会 有 两 个 文件 , 分 别 为 person.sql 和 person.txt。person.sql 
包含 创建 person 表 的 CREATE 语句 ， 其 内 容 如 下 : 
/*140103 SET TIME ZONE="'+00:00' */; 


/*!40101 SET @OLD SQL MODE=@@SQL MODE, SQL MODE="'' */; 
/*!40111 SET @OLD SQL NOTES=@@SQL NOTES, SQL NOTES=0 */; 


-- Table structure for table ‘person. 


DROP TABLE IF EXISTS ‘person; 
/*!40101 SET @saved cs_ client = @@character set client */; 
/*!40101 SET character set client = utf8 */; 
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CREATE TABLE ‘person. ( 

‘id int(10) unsigned NOT NULL AUTO INCREMENT, 

“name. char (40) NOT NULL DEFRULT '', 

“age” int(11) NOT NULL DEFAULT '0', 

“info* char (50) DEFAULT NULL, 

PRIMARY KEY (“id') 
) ENGINE=InnoDB AUTO INCREMENT=11 DEFAULT CHARSET=utf8; 
/*!40101 SET character set client = @saved cs client */; 


/*!140103 SET TIME ZONE=@OLD TIME ZONE */; 


/*!40101 SET SQL MODE=@OLD SQL MODE */; 
/*!40101 SET CHARACTER SET CLIENT=@OLD CHARACTER SET CLIENT */; 


/*!40101 SET CHARACTER SET RESULTS=@OLD CHARACTER SET RESULTS */; 


/*!40101 SET COLLATION CONNECTION=@OLD COLLATION CONNECTION */; 
/*!40111 SET SQL NOTES=@OLD SQL NOTES */; 


-- Dump completed on 2011-08-19 15:02:16 


备份 文件 中 的 信息 如 18.1.1 节 介 绍 。 
person.txt 包含 数据 包 中 的 数据 ， 其 内 容 如 下 : 


1 Green 2 Lawyer 

2 Suse 22 dancer 

3 Mary 24 Musician 

4 Willam 20 sports man 
三 Laura 25 \N 

6 Evans ei secretary 
a Dale 22 cook 

8 Edison 28 singer 

9 Harry 21 magician 
10 Harriet 19 pianist 


【 例 18.14】 使 用 MySQLdump 命令 将 test 数据 库 中 的 person 表 中 的 记录 导出 到 文本 文件 ， 使 
用 FIELDS 选项 ， 要 求 字段 之 间 使 用 逗号 “,” 间 隔 ， 所 有 字符 类 型 字段 值 用 双 引 号 括 起 来 ， 定 义 


转 义 字符 为 问号 “?”， 每 行 记录 以 回 车 换行 符 “\n” 结 尾 ， 执 行 的 命令 如 下 : 


C:\>mysqldump -T C:\backup test person -u root -p --fields-terminated-by=, 


--fields-optionally-enclosed-by=\" --fields-escaped-by=? 


--lines-terminated-by=\r\n 


上 面 语句 要 在 一 行 中 输入 ， 语 句 执 行 成 功 ， 系 统 C:\backup 目录 下 面 将 会 有 两 个 文件 ， 分 别 为 


person.sql 和 person.txt。person.sql 包含 创建 person 表 的 CREATE 语句 ， 其 内 容 与 前 面 例子 


同 ，person.txt 文件 的 内 容 与 上 一 个 例子 不 同 ， 显 示 如 下 : 


1,"Green",21, "Lawyer" 
2:"SuSe",22,"dancer" 


的 相 
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3,"Mary",24,"Musician" 
4,"Willam",20,"sports man" 
Sr"Laura”,25, 2N 
6,"Evans",27,"secretary" 
7,"Dale",22,"cook" 
8,"Edison",28,"singer" 
9,"Harry",21, "magician" 
10,"Harriet",19,"pianist" 


可 以 看 到 ,只 有 字符 类 型 的 值 被 双 引 号 括 了 起 来 , 而 数值 类 型 的 值 没有 ;第 5 行 记录 中 的 NULL 
值 表 示 为 “2N”， 使 用 问号 “?” 替 代 了 系统 默认 的 反 斜 线 转 义 字符 “\” 。 


18.4.3 使 用 MySQL 命令 导出 文本 文件 


MySQL 是 一 个 功能 丰富 的 工具 命令 , 使 用 MySQL 还 可 以 在 命令 行 模式 下 执行 SQL 指令 , 将 
查询 结果 导入 到 文本 文件 中 。 相 比 MySQLdump，MySQL 工具 导出 的 结果 可 读 性 更 强 。 

如 果 MySQL 服务 器 是 单独 的 机 器 ， 用 户 是 在 一 个 client 上 进行 操作 ， 用 户 要 把 数据 结果 导入 
到 client 机 器 上 。 可 以 使 用 MySQL -e 语句 。 

使 用 MySQL 导出 数据 文本 文件 语句 的 基本 格式 如 下 : 


mysql -u root -p --execute= "SELECT 语句 " dbname > filename.txt 
该 命令 使 用 --execute 选项 ， 表 示 执 行 该 选项 后 面 的 语句 并 退出 ， 后 面 的 语句 必须 用 双 引 号 括 
起 来 ，dbname 为 要 导出 的 数据 库 名 称 ， 导 出 的 文件 中 不 同 列 之 间 使 用 制 表 符 分 隔 ， 第 1 行 包含 了 
各 个 字段 的 名 称 。 
【 例 18.15】 使 用 MySQL 语句 ， 导 出 test 数据 库 中 person 表 中 的 记录 到 文本 文件 ， 输 入 语句 
如 下 : 


mysql -u root -p --execute="SELECT * FROM person;" test > C:\person3.txt 


语句 执行 完毕 之 后 ， 系 统 C 盘 目 录 下 面 将 会 有 名 称 为 person3.txt 的 文本 文件 ， 其 内 容 如 下 : 





id name age info 

1 Green 2 Lawyer 

六 Suse 2 dancer 

3 Mary 24 Musician 
4 Willam 20 sports man 
5 Laura 25 NULL 

6 Evans 2 secretary 
元 Dale 和 22 cook 

8 Edison 28 singer 

9 Harry 2 magician 
10 Harriet 19 pianist 


可 以 看 到 ，person3.txt 文件 中 包含 了 每 个 字段 的 名 称 和 各 条 记录 ， 该 显示 格式 与 MySQL 命令 
行 下 SELECT 查询 结果 显示 相同 。 
使 用 MySQL 命令 还 可 以 指定 查询 结果 的 显示 格式 , 如 果菜 行 记录 字段 很 多 , 可 能 一 行 不 能 完 
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全 显示 ， 可 以 使 用 --vartical 参数 ， 将 每 条 记录 分 为 多 行 显示 。 
【 例 18.16】 使 用 MySQL 命令 导出 test 数据 库 中 person 表 中 的 记录 到 文本 文件 , 使 用 --vertical 
参数 显示 结果 ， 输 入 语句 如 下 : 


语句 执行 之 后 ，Cxperson4.txt 文件 中 的 内 容 如 下 : 
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name: Edison 
age: 28 
info: singer 


类 磋 大 日 。 IOW 大 炎 到 


name: Harry 
age: 21 

info: magician 

太太 10。 rOW 大 太太 
i 

name: Harriet 
age: 19 

info: pianist 


可 以 看 到 ，SELECT 的 查询 结果 导出 到 文本 文件 之 后 ， 显 示 格 式 发 生 了 变化 ， 如 果 person 表 
中 记录 内 容 很 长 ， 这 样 显示 将 会 更 加 容易 阅读 。 
MySQL 可 以 将 查询 结果 导出 到 html 文件 中 ， 使 用 --html 选项 即 可 。 


【 例 18.17】 使 用 MySQL 命令 导出 test 数据 库 中 person 表 中 的 记录 到 html 文件 ， 输 入 语句 如 


mysql -u root -p --html --execute="SELECT * FROM person;" test > C:\person5.html 


语句 执行 成 功 ， 将 在 C 盘 创 建文 件 person5.html， 该 文件 在 浏览 器 中 显示 如 图 18-1 所 示 。 





- 0 x 
名 ] Ci\personS.html 只 - 上 Ec\personS.html 


id name age info 

1 Green | 21 Lawyer 

2 Suse 22 jdancer 

3 Mary 24 Musician 

4 Willam 20 sports man 
5 Laura | 25 NULL 

6 Evans |27 jsecretary 
7 Dale |22 lcook 

8 Edison |28 |singer 

9 Harry 21 magician 

1 


0 Harriet 19 pianist 











图 18-1 使 用 MySQL 导出 数据 到 html 文件 
如 果 要 将 表 数据 导出 到 xml 文件 中 ， 可 使 用 --xml 选项 。 
【 例 18.18】 使 用 MySQL 命令 导出 test 数据 库 中 person 表 中 的 记录 到 xml 文件 ， 输 入 语句 如 


mysql -u root -p --xml --execute="SELECT * FROM person;" test > C:\person6.xml 
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语句 执行 成 功 ， 将 在 C 盘 创 建文 件 person6.xml， 该 文件 在 浏览 器 中 显示 如 图 18-2 所 示 。 


一 口 x 





目 ] CNperson5html P70 cpersonShtml 


<?xml version="1.0" ?> 
- <resultset statement="SELECT * FROM person” 
xmins:xsi="http:/ /www.w3.0org/2001/XMLSchema-instance"> 
- <row> 
<field name="id">1</field> 
<field name="name">Green</field> 
<field name="age" >21</field> 
<field name="info">Lawyer</field> 
</row> 
- <row> 
<field name="id">2</field> 
<field name="name">Suse</field> 
<field name="age">22</field> 
<field name="info">dancer</field> 
</row> 
- <row> 
<field name="id">3</field> 
<field name="name">Mary </field> 


图 18-2 使 用 MySQL 导出 数据 到 xml 文件 
18.4.4 使 用 LOAD DATA INFILE 方式 导入 文本 文件 


MySQL 允许 将 数据 导出 到 外 部 文件 ， 也 可 以 从 外 部 文件 导入 数据 。MySQL 提供 了 一 些 导 入 
数据 的 工具 ， 这 些 工具 有 LOAD DATA 语句 、source 命令 和 MySQL 命令 。LOAD DATA INFILE 
语句 用 于 高 速 地 从 一 个 文本 文件 中 读 取 行 ,， 并 装 入 一 个 表 中 。 文件 名 称 必 须 为 文字 字符 串 。 本 节 将 
介绍 LOAD DATA 语句 的 用 法 。 

LOAD DATA 语句 的 基本 格式 如 下 : 


LOAD DATA INFILE 'filename.txt' INTO TABLE tablename [OPTIONS] [IGNORE number 
LINES] 











-- OPTIONS 选项 
FIELDS TERMINATED BY 'value' 
FIELDS [OPTIONALLY] ENCLOSED BY 'value' 
FIELDS ESCAPED BY 'value' 
LINES STARTING BY 'value' 
LINES TERMINATED BY 'value' 


可 以 看 到 LOAD DATA 语句 中 ， 关 键 字 INFILE 后 面 的 filename 文件 为 导入 数据 的 来 源 ; 
tablename 表示 待 导 入 的 数据 表 名 称 ;，[OPTIONS] 为 可 选 参数 选项 ，OPTIONS 部 分 的 语法 包括 
FIELDS 和 LINES 子 句 ， 其 可 能 的 取 值 有 : 

@ FIELDS TERMINATED BY 'value': 设置 字段 之 间 的 分 隔 字符 ， 可 以 为 单个 或 多 个 字符 ， 

默认 情况 下 为 制 表 符 “\t" 。 

@ FIELDS [OPTIONALLY] ENCLOSED BY 'value': 设置 字段 的 包围 字符 ， 只 能 为 单个 字符 。 

如 果 使 用 了 OPTIONALLY， 则 只 有 CHAR 和 VERCHAR 等 字符 数据 字段 被 包括 。 
@ FIELDS ESCAPED BY 'value' 控制 如 何 写 入 或 读 取 特殊 字符 ， 只 能 为 单个 字符 ， 即 设 
置 转 义 字符 ， 默 认 值 为 “\”。 
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@ LINES STARTING BY 'value': 设置 每 行 数 据 开头 的 字符 ， 可 以 为 单个 或 多 个 字符 ， 黑 
认 情 况 下 不 使 用 任何 字符 。 
@ LINES TERMINATED BY'value': 设置 每 行 数 据 结尾 的 字符 ， 可 以 为 单个 或 多 个 字符 ， 
默认 值 为 “\n”。 
IGNORE number LINES 选项 表示 忽略 文件 开始 处 的 行 数 ,number 表 示 忽 略 的 行 数 。 执 行 LOAD 
DATA 语句 需要 FILE 权限 。 
【 例 18.19】 使 用 LOAD DATA 命令 将 C:\person0.txt 文件 中 的 数据 导入 到 test 数 据 库 中 的 person 
表 ， 输 入 语句 如 下 : 


LOAD DATA INFILE 'C:\person0.txt' INTO TABLE test.person; 


恢复 之 前 ， 将 person 表 中 的 数据 全 部 删除 ， 登 录 MySQL， 使 用 DELETE 语句 ， 语 句 如 下 : 


mysql> USE test; 

Database changed; 

mysql> DELETE FROM person; 

Query OK, 10 rows affected (0.00 sec) 


从 person0.txt 文件 中 恢复 数据 ， 语 句 如 下 : 


mysql> LOAD DATA INFILE 'C:\person0.txt' INTO TABLE test.person; 
Query OK, 10 rows affected (0.00 sec) 
Records: 10 Deleted: 0 Skipped: 0 Warnings: 0 





mysql> SELECT * FROM person; 





+----+--------- + 一 一 -一 +------------ 十 
id | name | age | info | 
+ 一 -一 -+ 一 一 一 一 一 一 一 一 一 +----- 十 一 一 一 一 一 一 一 一 一 一 一 一 + 
1 | Green | 21 | Lawyer | 
21Suse | 22 1 dancer | 
3 | Mary | 24 | Musician | 
| 4 | Willam | 20 | sports man | 
L's Lavra | 25 | .NULL | 
6 | Evans | 27 | secretary | 
Tl pale | 22 | cook 1 
8 | Edison | 28 | singer | 
9 Barry [| 2 | magician "| 
L110 | Narriet | 19° | pianist | 
+ 一 一 一- 二 一 一 一 一 一 一 一 一 一 + 一 一 -一 +- 一 -一 一 一 一 一 一 一 一 一 一 + 


10 rows in set (0.00 sec) 
可 以 看 到 ， 语 句 执行 成 功 之 后 ， 原 来 的 数据 重新 恢复 到 了 person 表 中 。 


【 例 18.20] 使 用 LOAD DATA 命令 将 C:personl:txt 文 件 中 的 数据 导入 到 test 数 据 库 中 的 person 
表 ， 使 用 FIELDS 选项 和 LINES 选项 ， 要 求 字段 之 间 使 用 逗号 “,” 间 隔 ， 所 有 字段 值 用 双 引 号 括 
起 来 ， 定 义 转 义 字符 为 单 引号 “\”， 每 行 记录 以 回 车 换行 符 “\m” 结 尾 ， 输 入 语句 如 下 : 
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LOAD DATA INFILE 'C:\personl.txt' INTO TABLE test.person 
FIELDS 

TERMINRTED BY ',"' 

ENCLOSED BY '\"!' 

ESCAPED BY '\'' 

LINES 

TERMINATED BY '\r\n'; 


恢复 之 前 ， 将 person 表 中 的 数据 全 部 删除 ， 使 用 DELETE 语句 ， 执 行 过 程 如 下 : 


mysql> DELETE FROM person; 
Query OK，10 rows affected (0.00 sec) 


从 person1.txt 文件 中 恢复 数据 ， 执 行 过 程 如 下 : 
mysql> LOAD DATA INFILE 'C:\Personl.txt' INTO TABLE test.person 
-> FIELDS 
-> TERMINATED BY ',"' 
-> ENCLOSED BY '\"' 
-> ESCAPED BY '\'" 
-> LINES 
-> TERMINATED BY '\r\n'; 
Query OK, 10 rows affected (0.00 sec) 
Records: 10 Deleted: 0 Skipped: 0 Warnings: 0 


语句 执行 成 功 ， 使 用 SELECT 语句 查看 person 表 中 的 记录 ， 结 果 与 前 一 个 例子 相同 。 
18.4.5 ”使 用 MySQLimport 命令 导入 文本 文件 


使 用 MySQLimport 可 以 导入 文本 文件 ， 并 且 不 需要 登录 MySQL 客户 端 。MySQLimport 命令 
提供 许多 与 LOAD DATA INFILE 语句 相同 的 功能 ， 大 多 数 选 项 直接 对 应 LOAD DATA INFILE 子 
句 。 使 用 MySQLimport 语句 需要 指定 所 需 的 选项 、 导 入 的 数据 库 名 称 以 及 导入 的 数据 文件 的 路 径 
和 名 称 。MySQLimport 命令 的 基本 语法 格式 如 下 : 

mysqlimport -~u root-p dbname filename .txt [OPTIONS] 


--OPTIONS 选项 
--fields-terminated-by=value 
--fields-enclosed-by=value 
--fields-optionally-enclosed-by=value 
--fields-escaped-by=value 
--lines-terminated-by=value 
--ignore-lines=n 


dbname 为 导入 的 表 所 在 的 数据 库 名 称 。 注意, MySQLimport 命令 不 指定 导入 数据 库 的 表 名 称 ， 
数据 表 的 名 称 由 导入 文件 名 称 确定 ， 即 文件 名 作为 表 名 ， 导 入 数据 之 前 该 表 必须 存在 。[OPTIONS] 
为 可 选 参数 选项 ， 其 常见 的 取 值 有 : 
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【 例 18.21 使 用 MySQLimport 命令 将 C:\backup 目录 下 的 person.txt 文件 内 容 导入 到 test 数据 


--fields-terminated-by= 'Value': 设置 字段 之 间 的 分 隔 字 符 ， 可 以 为 单个 或 多 个 字符 ， 默 认 
情况 下 为 制 表 符 “\t”。 

--fields-enclosed-by= 'value': 设置 字段 的 包围 字符 。 

--fields-optionally-enclosed-by= "value': 设置 字段 的 包围 字符 ,只 能 为 单个 字符 ,包括 CHAR 
和 VERCHAR 等 字符 数据 字段 。 

--fields-escaped-by= "value': 控制 如 何 写 入 或 读 取 特殊 字符 ， 只 能 为 单个 字符 ， 即 设置 转 
义 字 符 ， 默 认 值 为 反 斜 线 “\”。 

--lines-terminated-by= "value': 设置 每 行 数据 结尾 的 字符 ， 可 以 为 单个 或 多 个 字符 ， 默 认 
值 为 “\n”。 

--ignore-lines=n: 忽视 数据 文件 的 前 n 行 。 





库 中 , 字段 之 间 使 用 逗号 “,” 间 隔 , 字符 类 型 字段 值 用 双 引 号 括 起 来 , 将 转 义 字符 定义 为 问号 “?”， 
每 行 记录 以 回 车 换行 符 “\nn” 结 尾 ， 执 行 的 命令 如 下 : 
C:\ >mysqlimport -u root -p test C:\backup/person.txt --fields-terminated-by=, 


--fields-optionally-enclosed-by=\" --fields-escaped-by=? --lines-terminated 
-by=\r\n 


上 面 语句 要 在 一 行 中 输入 ， 语 句 执行 成 功 ， 将 把 person.txt 中 的 数据 导入 到 数据 库 。 
除了 前 面 介绍 的 几 个 选项 之 外 ，MySQLimport 支持 许多 选项 ， 常 见 的 选项 有 : 


--columns=column_list, -c column_list: 该 选项 采用 过 号 分 隔 的 列 名 作为 其 值 。 列 名 的 顺序 

指示 如 何 匹 配 数据 文件 列 和 表 列 。 

--compress，-C: 压缩 在 客户 端 和 服务 器 之 间 发 送 的 所 有 信息 (如果 二 者 均 支持 压缩 )。 

-d，--delete: 导入 文本 文件 前 清空 表 。 

--force， 下 忽视 错误 。 例 如 ， 如 果菜 个 文本 文件 的 表 不 存在 ， 继 续 处 理 其 他 文件 。 不 使 

用 --force， 如 果 表 不 存在 ， 则 MySQLimport 退出 。 

--host=host_name，-h host_name: 将 数据 导入 给 定 主机 上 的 MySQL 服务 器 。 默 认 主机 是 

localhost. 

--ignore，-i: 参见 --replace 选项 的 描述 。 

--ignore-lines=n: 忽视 数据 文件 的 前 n 行 。 

--local，-L: 从 本 地 客户 端 读 入 输入 文件 。 

--lock-tables，-l: 处 理 文本 文件 前 锁定 所 有 表 以 便 写 入 。 这 样 可 以 确保 所 有 表 在 服务 器 上 

保持 同步 。 

--password[=password]，-p[password]: 当 和 连接 服务 器 时 使 用 的 密码 。 如 果 使 用 短 选项 形式 
(-p)， 选 项 和 密码 之 间 不 能 有 空格 。 如 果 在 命令 行 中 --password 或 -p 选项 后 面 没有 密码 

值 ， 则 提示 输入 一 个 密码 。 

--port=port_ num，-P port_ num: 用 于 连接 的 TCP/IP 端口 号 。 

--protocol={TCP | SOCKET | PIPE | MEMORY}: 使 用 的 连接 协议 。 

--replace，-r --replace 和 --ignore 选项 控制 复制 唯一 键 值 已 有 记录 的 输入 记录 的 处 理 。 如 果 

指定 --replace， 新 行 替 换 有 相同 的 唯一 键 值 的 已 有 行 ; 如 果 指 定 --ignore， 复 制 已 有 的 唯一 

键 值 的 输入 行 被 跳 过 ; 如 果 不 指定 这 两 个 选项 ， 当 发 现 一 个 复制 键 值 时 会 出 现 一 个 错误 ， 
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并 且 忽 视 文本 文件 的 剩余 部 分 。 

--silent，-s: 沉默 模式 。 只 有 出 现 错误 时 才 输 出 信息 。 

--User=user_ name，-uuser name: 当 连 接 服 务 器 时 MySQL 使 用 的 用 户 名 。 
--verbose，-V: 宛 长 模式 。 打 印 出 程序 操作 的 详细 信息 。 

--Version，-V: 显示 版 本 信息 并 退出 。 


18.5 ”实战 演练 一 一 数据 的 备份 与 恢复 


备份 有 助 于 保护 数据 库 , 通过 备份 可 以 完整 保存 MySQL 中 各 个 数据 库 的 特定 状态 。 在 系统 出 
现 故障 、 数 据 丢失 或 者 不 合理 操作 对 数据 库 造 成 灾难 时 ， 可 以 通过 恢复 恢复 数据 库 中 的 数据 。 作 为 
MySQL 的 管理 人 员 ， 应 该 定期 地 备份 所 有 活动 的 数据 库 ， 以 免 发生 数 据 丢 失 。 因 此 ， 无 论 怎样 强 
调 数据 库 的 备份 工作 都 不 过 分 。 本 章 综 合 案例 将 向 读者 提供 数据 库 备 份 与 恢复 的 方法 与 过 程 。 


1. 案例 目的 
按照 操作 过 程 完成 对 test 数据 库 的 备份 和 恢复 。 


加 使 用 MySQLdump 命令 将 suppliers 表 备份 到 文件 C\bktestdinsuppliers_bk.sql。 

加 使 用 MySQL 命令 恢复 suppliers 表 到 test 数据 库 中 。 

加 使 用 SELECT.. INTO OUTFILE 语句 导出 suppliers 表 中 的 记录 ， 导 出 文件 位 于 目录 
Ci\bktestdir 下 ， 名 称 为 suppliers_out.txt。 

加 使 用 LOAD DATA INFILE 语句 导入 suppliers_out.txt 数据 到 suppliers 表 。 

加 使 用 MySQLdump 命 令 将 suppliers 表 中 的 记录 导出 到 文件 CNbktestdinsuppliers_htmlhtml。 


2. 案例 操作 过 程 
四 使 用 MySQLdump 命令 将 suppliers 表 备份 到 文件 C:\bktestdirsuppliers_bk.sql。 
首先 创建 系统 目录 , 在 系统 C 盘 下 面 新 建文 件 夹 bktestdir, 然后 打开 命令 行 窗口 , 输入 语句 如 








C:\ >mysqldump -u root -p test suppliers > C:\bktestdir\suppliers bk.sql 
Enter password: ** 


语句 执行 完毕 ,打开 目录 Ci\bktestdir， 可 以 看 到 已 经 创建 好 的 备份 文件 suppliers_bk.sql， 内 容 
如 下 : 
-- MySQL dump 10.13 Distrib 5.7.10, for Win32 (x86) 


-= Host; localhost Database: test 


/*!40101 SET @OLD CHARACTER SET CLIENT=@@CHARACTER SET CLIENT */; 
/*!140101 SET @OLD CHARACTER SET RESULTS=@@CHARACTER SET RESULTS */; 
/*!140101 SET @OLD COLLATION CONNECTION=@@COLLATION CONNECTION */; 
/*!140101 SET NAMES utf8 */; 
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/*!40103 SET @OLD TIME ZONE=@@TIME ZONE */; 

/*!140103 SET TIME ZONE='+00:00' */; 

/*!40014 SET OLD UNIQUE CHECKS=@@UNIQUE CHECKS, UNIQUE CHECKS=0 */; 
/*!40014 SET QOLD FOREIGN KEY CHECKS=Q@@FOREIGN KEY CHECKS, FOREIGN KEY_ 
CHECKS=0 */; 

/*!40101 SET OLD SQL MODE=@@SQL MODE, SQL MODE='NO AUTO VALUE ON ZERO'*/; 
/*!40111 SET OLD SQL NOTES=@@SQL NOTES, SQL NOTES=0 */; 


-- Table structure for table ‘suppliers. 


DROP TABLE IF EXISTS ‘suppliers’; 
/*!40101 SET @saved cs client = @@character set client */; 
/*!40101 SET character set client = utf8 */; 
CREATE TABLE ‘suppliers. ( 

“s_id int(11) NOT NULL AUTO_ INCREMENT, 

`“s_name ”char (50) NOT NULL, 

`“s_city”char (50) DEFAULT NULL, 

`“s_zip ”char(10) DEFAULT NULL, 

`“s_cal1”char (50) NOT NULL, 

PRIMARY KEY (“s_id*) 
) ENGINE=InnoDB AUTO_ INCREMENT=108 DEFAULT CHARSET=utf8; 
/*!40101 SET character set client = @saved cs client */; 


-- Dumping data for table “suppliers 


LOCK TABLES ‘suppliers. WRITE; 

/*!40000 ALTER TABLE ‘suppliers. DISABLE KEYS */; 

INSERT INTO ‘suppliers. VALUES (101,'FastFruit Inc.','Tianjin','463400', 
'48075'), (102, 'LT Supplies',' Chongqing','100023','44333'), (103,'ACME', 
'Shanghai','100024','"'90046'), (104, 'FNK Inc.','Zhongshan','212021°',"'11111°'), 

(105, 'Good Set','Taiyuang','230009','22222'), (106,'Just Eat Ours','Beijing', 
"010"','45678"'), (107, 'DK Inc.','Qingdao’, "230009','33332'); 

/*!40000 ALTER TABLE ‘suppliers. ENABLE KEYS */; 

UNLOCK TABLES; 

/*!40103 SET TIME ZONE=Q@OLD TIME ZONE */; 


/*!140101 SET SQL MODE=Q@OLD SQL MODE */; 

/*!40014 SET FOREIGN KEY CHECKS=@OLD FOREIGN KEY CHECKS */; 
/*!140014 SET UNIQUE CHECKS=Q@OLD UNIQUE CHECKS */; 

/*!140101 SET CHARACTER SET CLIENT=Q@OLD CHARACTER SET CLIENT */; 
/*!40101 SET CHARACTER SET RESULTS=@OLD CHARACTER SET RESULTS */; 
/*!40101 SET COLLATION CONNECTION=@OLD COLLATION CONNECTION */; 
/*!140111 SET SQL NOTES=@OLD SQL NOTES */; 


辆 使 用 MySQL 命令 将 备份 文件 suppliers_bk.sql 中 的 数据 恢复 suppliers 表 。 
为 了 验证 恢复 之 后 数据 的 正确 性 ， 删 除 suppliers 表 中 的 所 有 记录 ， 登 录 MySQL， 输 入 语句 : 


mysql> USE test; 
Database changed 
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mysql> DELETE FROM suppliers; 
Query OK, 7 rows affected (0.00 sec) 


此 时 ，suppliers 表 中 不 再 有 任何 数据 记录 ， 在 MySQL 命令 行 输入 恢复 语句 如 下 : 

mysql> source C:\bktestdir\suppliers bk.sql; 

语句 执行 过 程 中 会 出 现 多 行 提示 信息 ， 执 行 成 功 之 后 使 用 SELECT 语句 查询 suppliers 表 ， 内 
容 如 下 : 

mysql> SELECT * FROM suppliers; 


+------ 二 -一 一 一 一 一 一 一 一 一 一 一 一 一 一 +------ 一 -一 -一 一- 一 + 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 
| sid | s name Ursceity Usrzip sacarr ll 

+------ +----------------- +--------------: + 一 一 一 一 一 一 一 一 一 + 一 一 一 一 一 一 一 一 + 
| 101 | FastFruit Inc. | Tianjin | 463400 | 480751 

| 102 | LT Supplies | Chongqing | 100023 | 443331 

| 103 | ACME | Shanghai | 100024 | 900461 

| 1204 IENRI Tc | Zhongshan | 212021 | 111111 

| 105 | Good Set | Taiyuang | 230009 | 222221 

| 106 | Just Eat Ours | Beijing 1 010 1 45678 | 

1 "07 | DR Tnc | Qingdao | 230009 | 33332 | 

+----- +----------------- +-------------- + 一 一 一 一 一 一 一 一 +-------- + 


7 rows in set (0.00 sec) 
由 查询 结果 可 以 看 到 ， 恢 复 操作 成 功 。 


国 使 用 SELECT... INTO OUTFILE 语句 导出 suppliers 表 中 的 记录 ， 导 出 文件 位 于 目录 
C:bktestdir 下 ， 名 称 为 suppliers_out.txt。 


执行 过 程 如 下 : 


mysql> SELECT 区 FROM test.suppliers INTO OUTFILE 
"C:\bktestdir\suppliers out.txt" 
-> FIELDS 


-> TERMINATED BY ',"' 
-> ENCLOSED BY '\"' 
-> LINES 
-> STARTING BY '<' 
-> TERMINATED BY '>\r\n'; 
Query OK, 7 rows affected (0.00 sec) 


TERMINATED BY ', 指 定 不 同 字段 之 间 使 用 逗号 分 隔 开 ; ENCLOSED BY \" 指 定 字段 值 使 用 
双 引 号 包括 ; STARTING BY '< "指定 每 行 记录 以 左 箭头 符号 开始 ; TERMINATED BY >\m'; 指 定 每 
行 记录 以 右 箭头 符号 和 回 车 换行 符 结束 。 语句 执行 完毕 ,打开 目录 Ci\bktestdir, 可 以 看 到 已 经 创建 
好 的 导出 文件 suppliers_out.txt， 内 容 如 下 : 

<"“101","FastFruit Inc.", "Tianjin", "463400","48075"> 
<"102","LT Supplies","Chongqing","100023","44333"> 
<"103","ACME","Shanghai","100024","90046"> 

<"104", "FNK Inc.", "Zhongshan”, "212021";"11111"> 
<"105","Good Set","Taiyuang","230009","22222"> 
<"106","Just Eat Ours","Beijing","010","45678"> 
<"107","DK Tnc." "Qingdao™", "230009","33332"> 
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四 使 用 LOAD DATA INFILE 语句 导入 suppliers_out.txt 数据 到 suppliers 表 。 
首先 使 用 DELETE 语句 删除 suppliers 表 中 的 所 有 记录 ， 然 后 输入 导入 语句 : 


mysql> LOAD DATA INFILE 'C:\bktestdir\suppliers out.txt' INTO TABLE 
test.suppliers 
-> FIELDS 
-> TERMINATED BY ',"' 
-> ENCLOSED BY '\"' 
-> LINES 
-> STARTING BY '<' 
-> TERMINATED BY '>\r\n'; 
Query OK, 7 rows affected (0.00 sec) 
Records: 7 Deleted: 0 Skipped: 0 Warnings: 0 


语句 执行 之 后 ，suppliers_out.txt 文件 中 的 数据 将 导入 suppliers 表 中 ， 由 于 导出 txt 文件 时 指定 
了 一 些 特殊 字符 ， 因 此 恢复 语句 中 也 要 指定 这 些 字 符 ， 已 确保 恢复 后 数据 的 完整 性 和 正确 性 。 
加 使 用 MySQLdump 命 令 将 suppliers 表 中 的 记录 导出 到 文件 Ci\bktestdir\suppliers_html.html。 


导出 表 数 据 到 html 文件 ， 使 用 MySQL 命令 时 需要 指定 --html 选项 ， 在 Windows 命令 行 窗口 
输入 导出 语句 如 下 : 


mysql -u root -p --html --execute="SELECT * FROM suppliers;" test > 
C:\bktestdir\suppliers html .html 


语句 执行 完毕 ， 打 开 目 录 Ci\bktestdir， 可 以 看 到 已 经 创建 好 的 导出 文件 suppliers_html.html， 
读者 可 以 使 用 浏览 器 打开 该 文件 ， 在 浏览 器 中 显示 格式 和 内 容 如 表 18-1 所 示 。 


表 18-1 浏览 器 中 显示 导出 文件 的 内 容 





s name S S_zip S_call 


| 463400 48075 
| im | LTSupplies 100023 44333 
ACME I 100024 


| FNKIne | zhongshan | 212021 11111 


105 Good Set Taiyuang 230009 
Just Eat Ours Beijing 010 
107 DK Inc. Qingdao 230009 33332 


18.6 ”高 手 私房 菜 


技巧 1: MySQLdump 备份 的 文件 只 能 在 MySQL 中 使 用 吗 ? 

MySQLdump 备份 的 文本 文件 实际 是 数据 库 的 一 个 副本 ， 使 用 该 文件 不 仅 可 以 在 MySQL 中 恢 
复数 据 库 ， 而 且 通 过 对 该 文件 的 简单 修改 ， 可 以 使 用 该 文件 在 SQL Server 或 者 Sybase 等 其 他 数据 
库 中 恢复 数据 库 。 这 在 某 种 程度 上 实现 了 数据 库 之 间 的 迁移 。 
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技巧 2: 如 何 选择 备份 工具 ? 

直接 复制 数据 文件 是 最 为 直接 、 快 速 的 备份 方法 ， 但 缺点 是 基本 上 不 能 实现 增 量 备 份 。 备 份 
时 必须 确保 没有 使 用 这 些 表 。 如 果 在 复制 一 个 表 的 同时 服务 器 正在 修改 它 ， 则 复制 无 效 。 备 份 文件 
时 ， 最 好 关闭 服务 器 ， 然 后 重新 启动 服务 器 。 为 了 保证 数据 的 一 致 性 ， 需 要 在 备份 文件 前 ， 执 行 以 
下 SQL 语句 : 


FLUSH TABLES WITH READ LOCK; 


也 就 是 把 内 存 中 的 数据 都 刷新 到 磁盘 中 ， 同 时 锁定 数据 表 ， 以 保证 复制 过 程 中 不 会 有 新 的 数 
据 写 入 。 这 种 方法 备份 出 来 的 数据 恢复 也 很 简单 ， 直 接 复 制 回 原来 的 数据 库 目 录 下 即 可 。 

MySQLhotcopy 是 一 个 PERL 程序 , 它 使 用 LOCK TABLES、FLUSH TABLES 和 cp 或 scp 
来 快速 备份 数据 库 。 它 是 备份 数据 库 或 单个 表 的 最 快 的 途径 , 但 它 只 能 运行 在 数据 库 文件 所 在 的 机 
器 上 , 并 且 MySQLhotcopy 只 能 用 于 备份 MyISAM 表 。MySQLhotcopy 适合 于 小 型 数据 库 的 备份 ， 
数据 量 不 大 ， 可 以 使 用 MySQLhotcopy 程序 每 天 进行 一 次 完全 备份 。 

MS np 将 数据 表 导 成 SQL 脚本 文件 ， dl MySQL 版 本 之 间 升 级 时 相对 比较 合适 ， 














技巧 3: 使 用 MySQLdump 备份 整个 数据 库 成 功 ， 把 表 和 数据 库 都 删除 了 ， 但 使 用 备份 
文件 却 不 能 恢复 数据 库 ? 

出 现 这 种 情况 ， 是 因为 备份 的 时 候 没有 指定 --databases 参数 。 默 认 情 况 下 ， 如 果 只 指定 数据 库 
名 称 ，MySQLdump 备份 的 是 数据 库 中 所 有 的 表 ， 而 不 包括 数据 库 的 创建 语句 ， 例 如 : 

mysqldump -u root -P booksDB > c:\backup\booksDB 20160101.sql 


该 语句 只 备份 了 booksDB 数据 库 下 所 有 的 表 ， 读 者 打开 该 文件 ， 可 以 看 到 文件 中 不 包含 创建 
booksDB 数据 库 的 CREATE DATABASE 语句 ， 因 此 如 果 把 booksDB 也 删除 了 , 使 用 该 sql 文件 不 
能 恢复 以 前 的 表 ， 恢 复 时 会 出 现 ERROR 1046 (3D000): No database selected 的 错误 信息 。 必 须 在 
MySQL 命令 行 下 创建 booksDB 数据 库 ， 并 使 用 use 语句 选择 booksDB 之 后 才 可 以 恢复 。 而 下 面 的 
语句 ， 数 据 库 删 除 之 后 ， 可 以 正常 恢复 备份 时 的 状态 。 


mysqldump -u root -P --databases booksDB > C:\backup\books DB 20160101.sql 


该 语句 不 仅 备 份 了 所 有 数据 库 下 的 表 结 构 ， 而 且 包 括 创建 数据 库 的 语句。 


18.7 ”经典 习题 


(1) 同时 备份 test 数据 库 中 的 fruits 和 suppliers 表 ， 然 后 删除 两 个 表 中 的 内 容 并 恢复 。 

(2) 将 test 数据 库 中 不 同 的 数据 表 中 的 数据 ， 导 出 到 xml 文件 或 者 html 文件 ， 并 查看 文件 内 
容 。 

(3) 使 用 MySQL 命令 导出 fruits 表 中 的 记录 ， 并 将 查询 结果 以 垂直 方式 显示 写 入 导出 文件 。 





第 19 章 PHP 操作 MySQL 数据 库 


PHP 是 一 种 简单 的 、 面 向 对 象 的 、 解 释 型 的 、 健 壮 的 、 安 全 的 、 性 能 非常 高 的 、 独 立 于 架构 
的 、 可 移植 的 和 动态 的 脚本 语言 。 而 MySQL 是 快速 和 开源 的 网 络 数据 库 系统 。PHP 和 MySQL 的 
结合 是 目前 Web 开发 的 黄金 组 合 ， 那 么 PHP 是 如 何 操作 MySQL 数据 库 的 呢 ? 本 章 将 开始 学 习 使 
用 PHP 操作 MySQL 数据 库 的 各 种 函数 和 技巧 。 


本 章 学 习 目 标 


熟悉 PHP 访问 MySQL 数据 库 的 一 般 步 骤 
熟悉 数据 库 连 接 前 的 准备 方法 

掌握 PHP 操作 MySQL 数据库 的 基本 操作 
掌握 添加 动态 用 户 信息 的 方法 

掌握 查询 数据 信息 的 方法 


19.1 PHP 访问 MySQL 数据 库 的 一 般 步 又 
通过 Web 访问 数据 库 的 工作 过 程 。 一 般 分 为 以 下 几 个 步骤 。 

(1) 用 户 使 用 浏览 器 对 某 个 页 面 发 出 HTTP 请 求 。 

(2) 服务 器 端 接收 到 请 求 ， 并 发 送 给 PHP 程序 进行 处 理 。 

(3) PHP 解析 代码 。 在 代码 中 有 连接 MySQL 数据 库 命令 和 请 求 特定 数据 库 的 某 些 特定 数据 
的 SQL 命令 。 根据 这 些 代 码 ，PHP 打开 一 个 和 MySQL 的 连接 ， 并 且 发 送 SQL 命令 到 MySQL 数 
据 库 。 

(4) MySQL 接收 到 SQL 语句 之 后 ， 加 以 执行 。 执 行 完 毕 后 返回 执行 结果 到 PHP 程序 。 

(5) PHP 执行 代码 ， 并 根据 MySQL 返回 的 请 求 结果 数据 ， 生 成 特定 格式 的 HTML 文件 ， 且 
传递 给 浏览 器 。HTML 经 过 浏览 器 泻 染 ， 就 是 用 户 请 求 的 展示 结果 。 


19.2 ”连接 数据 库 前 的 准备 工作 


默认 情况 下 ， 从 PHP 5 开始 ，PHP 不 再 自动 开启 对 MySQL 的 支持 ， 而 是 放 到 扩展 函数 库 中 。 
所 以 用 户 需要 在 扩展 函数 库 中 开启 MySQL 函数 库 。 

首先 打开 php.ini， 找 到 “; extension=php_mysqli.dll”， 去 掉 该 语句 前 的 分 号 “; ”,， 如 图 19-1 
所 示 ， 保 存 php.ini 文件 ， 重 新 启动 IIS 或 APACHE 服务 器 即 可 。 
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文件 (日 ” 编 蚀 (E) 格式 (O) 这 看 (V) 帮助 (H) 
;extension=php_1 
;extension=php. 



























; Must be after mbstring as it depends on it 


php_oci8_12c.dll ; Use with Oracle Database 12c Instant Client 
;extension=php_openssl. dll 
;extension=php_pdo_firebird. dll 
;extension=php_pdo_mysql. dll 
;extension=php_pdo_oci. dll 
;extension=php_pdo_odbc. dll 
;extension=php_pdo_pgsql. dll 
;extension=php_pdo_sqlite. dll 
;extension=php_pgsql. dll 
;extension=php_shmop. dll 


; The NMIBS data available in the PHP distribution must be installed. 
; See http://www. php. net/manual/en/snmp. installation. php 
;extension=php_snmp. dll 


;extension=php_soap. dll 
;extension=php_sockets. dll 








图 19-1 修改 PHPini 文件 


配置 文件 设置 完成 后 ， 可 以 通过 phpinfo(0) 函 数 来 检查 是 否 配置 成 功 ， 如 果 显 示 出 的 PHP 的 环 
境 配 置信 息 中 有 mysql 的 项 目 ， 表 示 已 经 开启 了 对 MySQL 数据 库 的 支持 ， 如 图 19-2 所 示 。 










































































由 - 已 htp//ocahost?phpinfo=1 四 D-cl| 豆 hpnea x I 
文件 /名 (查看 V】 履 磋 (A) 工具 Tm) 如 内 (H) 
~ 
mysqli 
Client Apl library version mysqind 5.0.12-dev - 20150407 - Sid 全 9cb767fe17a6679599b5c07E 
Active Persistent Links 0 
Inactive Persistent Links 0 
Active Links 0 
六 ww 
mysqli.allow_local_infile on On 
mysqliallow_persistent On On 
mysaqlidefault_host navalue no vaue 
mysali.default_port 3306 3306 
mysqlidefault_pw no velue no value 
mysqll.defaul_socket novalue no vaue 
mysaqli.default_user mo value mo value 
mysqlimax_links Uniimited Unlimited ~ 
< 》 








图 19-2 PHP 的 环境 配置 页 面 


19.3 ”访问 数据 库 


PHP 和 MySQL 数据 库 是 开发 动态 网 站 的 黄金 搭档 ， 本 节 将 讲述 PHP 如 何 访问 MySQL 数 
据 库 。 
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19.3.1 使 用 mysqli_connect() 函 数 连 接 MySQL 服务 器 


PHP 使 用 mysqli_connect() 函 数 连接 到 MySQL 数据 库 。 

mysqli_connect() 函 数 的 格式 如 下 : 

mysqli_connect ("MYSQL 服务 器 地 址 '，' 用 户 名 '，' 用户 密码 '，' 要 连接 的 数据 库 名 ' ) 
【 例 19.1】《〔 实 例文 件 ，ch19\19.1.php) 


<?php 
$db=mysqli_connect("localhost,'root,"753951'adatabase'); // 连 接 数据 库 


2 


该 语句 就 是 通过 此 函数 连接 到 MySQL 数据 库 并 且 把 此 连接 生成 的 对 象 传递 给 名 为 db 的 变 
量 ， 也 就 是 对 象 db。 其 中 “MySQL 服务 器 地 址 ”为 localhost，“ 用 户 名 ”为 root，“ 用 户 密码 ” 
为 本 环境 root 设 定 密码 753951，“ 要 连接 的 数据 库 名 ”为 adatabase。 

默认 情况 下 ，MySQL 服务 的 端口 号 为 3360， 如 果 采 用 默认 的 端口 号 ， 可 以 不 用 指定 ， 如 果 采 
用 了 其 他 的 端口 号 ， 比 如 采用 1066 端口 ， 则 需要 特别 指定 ， 例 如 127.0.0.1:1066， 表 示 MySQL 服 
务 于 本 地 机 器 的 1066 端口 。 


【 其 中 localhost 换 成 本 地 地 址 或 者 127.0.0.1， 都 能 实现 同样 的 效果 。 
提 示 


如 果 数 据 库 连 接 失败 ，PHP 会 发 出 警告 信息 ， 如 图 19-3 所 示 。 


OG Mp//ocalhosehls/! @ P ~ OB localhost x oa 
文件 (F) 。 坊 句 (E) ”可 看 (V) 收藏 夫 (A) ”工具 (D 帮助 (H) 




















1| 0.0010 351896|{main}() [15.1.php:0 
2| 0.0010 352008|mysqli connect() .15.1.php:2 











图 19-3 警告 信息 
警告 信息 中 ， 提 示 用 root 账号 无 法 连接 到 数据 库 服务 器 ， 并 且 该 警告 并 不 会 停止 脚本 的 继续 
执行 。 可 见 ， 这样 的 提示 信息 会 暴露 数据 库 连 接 的 敏感 问题 ,不 利于 数据 库 的 安全 性 。 如 果 想 提高 
安全 性 ， 避 免 错误 信息 的 输出 ， 可 以 加 上 @ 屏 蔽 错误 信息 ， 然 后 加 上 die0) 函 数 进行 屏蔽 的 错误 处 
理 机 制 。 
【 例 19.2】 《实例 文件 :ch1%\19.2.php) 
<?php 
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S$db=emysqli_connect('1localhost'v 'root'v '666666'，'adatabase') 
or die ("无 法 连接 到 服务 器 ”) ; // 连 接 数据 库 
print ("成 功 连接 到 服务 器 ”) ; 
mysqli close($db); 
2 
如 果 数据 库 连接 失败 ，PHP 会 发 出 警告 信息 ， 如 图 19-4 所 示 。 这 是 安全 地 连接 MySQL 数据 
库 服务 器 的 方法 。 

















HO eeenes 3 oo octon 


文件 (F) ” 蝙 辑 (E) ”可 看 (V) ”收藏 夫 (A) ”工具 (D) ”帮助 (H) 














HS 


( 
[CE 
afrine Menory [runction Jeocation | 
"无 法 连接 到 服务 器 ” 





图 19-4 警告 信息 
19.3.2 ”使 用 mysqli_select_db() 函 数 更 改 默认 的 数据 库 

连接 到 数据 库 以 后 ， 如果 需 要 更 改 默认 的 数据 库 ， 需 要 使 用 函数 mysqli_select_db()。 它 的 格式 

为 : 
mysqli_select_db (数据 库 服 务 器 连接 对 象 ， 更 改 后 的 数据 库 名 ) 

在 19.3.1 小 节 实 例 中 的 $db = mysqli_connect('localhost','root,'753951','adatabase"); 语 句 已 经 通过 
传递 参数 值 adatabase 确定 了 需要 操作 的 默认 数据 库 。 如 果 不 传递 此 参数 ，mysqli_connect() 函 数 只 
提供 “MySQL 服务 器 地 址 ”、“ 用 户 名 ”和 “用 户 密码 ”， 一 样 可 以 连接 到 MySQL 数据 库 服务 
器 并 且 以 相应 的 用 户 登 录 。 如 果 上 例 的 语句 变 为 $db = mysqli_connect('localhost','root,'753951"); 一 样 
是 可 以 成 立 的 。 

但 是 ， 在 这 样 的 情况 下 ， 就 必须 继续 选择 具体 的 数据 库 来 进行 操作 。 

如 果 把 19.1.php 文件 中 的 语句 : 

$db = mysqli_connect ('localhost','root','753951','adatabase'); 

修改 为 以 下 两 个 语句 替代 : 


$db = mysqli_connect ('localhost','root','753951°'); 
mysqli_select db($db,'adatabase'); 


程序 运行 效果 将 完全 一 样 。 
在 新 的 语句 中 mysqli_select_db($db,'adatabase"); 语 句 确 定 了 “数据 库 服 务 器 连接 对 象 ”为 $db， 
“目标 数据 库 名 ”为 adatabase。 
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19.3.3 ”使 用 mysqli_close() 函 数 关 闭 MySQL 连接 

在 连接 数据 库 时 ， 可 以 使 用 mysqli_connect() 函 数 。 与 之 相对 应 ， 在 完成 了 一 次 对 服务 器 的 使 
用 的 情况 下 ， 需 要 关闭 此 连接 ， 以 免 对 MySQL 服务 器 中 数据 进行 误 操作 并 对 资源 进行 释放 。 一 个 
服务 器 的 连接 也 是 一 个 对 象 型 的 数据 类 型 。 

mysqli_close() 函 数 的 格式 为 : 

mysqli_close (需要 关闭 的 数据 库 连接 对 象 ) 

在 本 实例 的 程序 中 mysqli_close($db); 语 句 关 闭 了 “需要 关闭 的 数据 库 连 接 对 象 ”为 gdb 对 象 。 
19.3.4 使 用 mysqli_query() 函 数 执行 SQL 语句 


使 用 mysqli_query() 函 数 执行 SQL 语句 ， 需 要 向 此 函数 中 传递 两 个 参数 ， 一 个 是 MySQL 数据 
库 服务 器 连接 对 象 ， 另 一 个 是 以 字符 串 表 示 的 SQL 语句 。mysqli_query0 函 数 的 格式 如 下 : 
mysqli_query (数据 库 服务 器 连接 对 象 , SQL 语句 ) 


在 运行 本 实例 前 ， 用 户 可 以 参照 前 面 章节 的 知识 , 在 MySQL 服务 器 上 创建 adatabase 数据 库 ， 
添加 数据 表 user， 数 据 表 user 主要 包括 Id 〈 工 号 ) 、Name (姓名 ) 、Age (年 龄 ) 、Gender (性 
别 ) 和 Info《〈 个 人 信息 ) 字段 ， 然 后 添加 一 些 演示 数据 即 可 。 


【 例 19.3】 实 例文 件 : ch19\19.3.php) 


<?php 
$db=@mysqli_connect('localhost', 'root','753951', 'adatabase') 
or die ("无 法 连接 到 服务 器 ") ; / /连接 数据 库 
/ /执行 插入 数据 操作 
$sq = "insert into userl(Id,Name,Age,Gender,Info) 
values (4,'fangfang',18,'female', 'She is a 18 years lady')"; 
$result = mysqli query ($db, $sq); //$result 为 boolean 类 型 
if ($result) { 
echo "插入 数据 成 功 ! <br/>"; 
} else { 
echo "插入 数据 失败 ! <br/>"; 
} 
// 执行 更 新 数据 操作 


$sq = "update user set Name=' 张 芳 ' where Name='fangfang'"; 











$result = mysqli query ($db, $sq); 
if($result) { 

echo "更 新 数据 成 功 !<br/>"; 

} else { 

echo "更 新 数据 失败 !<br/>"; 

下 

// 执行 查询 数据 操作 

$sq = "select * from user"; 


$result = mysqli query ($db, $sq); // 如 果 查 询 成 功 ，$result 为 资源 类 型 ， 保 存 查询 结果 集 
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mysqli_close(S$dqb) ; 
是 关 


程序 执行 后 的 结果 如 图 19-5 所 示 。 











@S 国 -| 等 mapyecs B Pr- ©| Blocalhost 
文件 (D ”编辑 (E) ”查看 (V) 收藏 夫 (A) ”工具 (D] 帮助 (H) 


























插入 数据 成 功 ! 
更 新 数据 成 功 ! 





图 19-5 程序 运行 结果 


可 见 ，mysqli_query() 函 数 执行 SQL 语句 之 后 会 把 结果 返回 。 上 例 中 就 是 返回 结果 并 且 赋 值 给 
$result 变量 。 


19.3.5 ”获取 查询 结果 集中 的 记录 数 


使 用 mysqli_num_rows() 函 数 获取 查询 结果 包含 的 数据 记录 的 条 数 ， 只 需要 给 出 返回 的 数据 对 
象 即 可 。 语 法 格式 如 下 : 


mysqli num rows (result); 


其 中 result 是 查询 结果 对 象 ， 此 函数 只 对 select 语句 有 效 。 
如 果 想 获取 查询 、 插 入 、 更 新 和 删除 操作 所 影响 的 行 数 ， 需 要 使 用 mysqli_affected_rows 函数 。 
mysqli_affected_rows() 函 数 返 回 前 一 次 MySQL 操作 所 影响 的 行 数 。 语 法 格式 如 下 : 


mysqli affected rows (connection) 


其 中 connection 为 必需 参数 ， 表 示 当 前 的 MySQL 连接 。 如 果 返 回 结果 为 0， 表示 没有 受 影 响 
的 记录 ; -1 表示 查询 返回 错误 。 

下 面 通 过 实例 来 讲解 它们 的 使 用 方法 和 区 别 。 

【 例 19.4】 《实例 文件 :ch19%\19.4.php) 


<?php 

$db=@mysqli_connect('localhost', 'root','753951', 'adatabase') 

or die ("无 法 连接 到 服务 器 ") ; ”/ /连接 数据 库 

/ /执行 查询 数据 操作 

$sq = "select * from user"; 

$result = mysqli_query ($db, $sq) ; // 如 果 查 询 成 功 ，$result 为 资源 类 型 ， 保 存 查询 结果 集 
echo "查询 结果 有 ". mysqli_num _rows ($result) ." 条 记录 "”<br/>; // 输 出 查询 记录 集 的 行 数 
// 执行 更 新 数据 操作 

$sq = "update user set Name='mingming' where Name=' 张 芳 '"; 

$result = mysqli query ($db, $sq); 

echo "更 新 J".mysqli_affected_rows ($db) . "条 记录 "; // 输 出 更 新 记录 集 的 行 数 
mysqli_ close($db); 

了 > 





PHP 操作 MySQL 数据 库 第 19 章 





程序 执行 后 的 结果 如 图 19-6 所 示 。 











Oe- hp//loca B PD- | Slocaltost 
文件 往 霸 (F) 可 乔 V) 收 惑 冯 A] 工具 0T) 者 助 () 
查询 结果 有 5 条 记录 
更 新 了 1 条 记录 

















图 19-6 程序 运行 结果 


19.3.6 ”获取 结果 集 的 一 条 记录 作为 枚 举 数 组 


执行 select 查询 操作 后 ， 使 用 mysqli_fetch_rows(0) 函 数 可 以 从 查询 结果 中 取出 数据 ， 如 果 想 逐 
行 取出 每 条 数据 ， 可 以 结合 循环 语句 循环 输出 。 
mysqli_fetch_rows() 函 数 的 语法 格式 如 下 : 


mysqli_ fetch rows (result); 
其 中 result 指 查询 结果 对 象 。 


【 例 19.5】〔 实 例文 件 ，ch19\19.5.php) 


<?php 
$db=@mysqli_connect('localhost', 'root','753951', 'adatabase') 
or die ("无 法 连接 到 服务 器 ") ; / /连接 数据 库 
mysqli_query("set names utf8"); // 设 置 MySQL 的 字符 集 ， 以 屏蔽 乱码 
/ /执行 查 询 数 据 操作 
$sq = "select * from user"; 
$result = mysqli_query ($db, $sq); // 如 果 查 询 成 功 ，$result 为 资源 类 型 ， 保 存 查 询 结 果 集 
<table width="370" border="]1" cellspacing="0" cellpadding="0"> 
<tr><th> 编 号 </th><th> 姓 名 </th><th> 年 龄 </th><th> 性 别 </th><th> 个 人 信息 /th></tr> 
<?php 
while ($row=mysqli_ fetch row ($result)){ // 逐 行 获取 结果 集中 的 记录 ， 并 显示 在 表格 中 


> 
<tr> 
<td><?php echo $row[0] ?></td> <!== 显示 第 一 列 =-> 
<td><?php echo $row[1] ?></td> 二 = 旺 不 第 三 列 攻 => 
<td><?php echo $row[2] ?></td> <!-= 显示 第 三 列 ==> 
<td><?php echo $row[3] ?></td> <!-- 显示 第 四 列 --> 
<td><?php echo $row[4] ?></td> <!-- 显示 第 五 列 --> 
</tr> 
<?php 


} 
mysqli_close($db); 
> 
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程序 执行 后 的 结果 如 图 19-7 所 示 。 
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图 19-7 程序 运行 结果 


19.3.7 ”获取 结果 集 的 记录 作为 关联 数组 

使 用 mysqli_fetch_assoc() 函 数 从 数组 结果 集中 获取 信息 ， 只 要 确定 SQL 请 求 返回 的 对 象 就 可 
以 了 。 语 法 格式 如 下 : 

mysqli_ fetch assoc (result); 

此 函数 与 mysqli_fetch_rows() 函 数 的 不 同 之 处 就 是 返回 的 每 一 条 记录 都 是 关联 数组 。 注意 ， 该 
函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


【 例 19.6】 “实例 文件 ，ch19\19.6.php) 


<?php 
while($row = mysqli fetch assoc($result)) { // 逐 行 获取 结果 集中 的 记录 
2> 
<tr> 
<td><?php echo $row["Id"] ?></td> <!-- 获取 当前 行 “Id” 字 段 值 --> 
<td><?php echo $row["Name"] ?></td> <!-- 获取 当前 行 “Name” 字 段 值 --> 
<td><?php echo $row["Age"] ?></td> <!-- 获取 当前 行 “Age” 字 段 值 --> 
<td><?php echo $row["Gender"] ?></td> <!-- 获取 当前 行 “Gender” 字 段 值 
--> 
<td><?php echo Srow["Info"] ?></td> <!-- 获取 当前 行 “Info” 字 段 值 --> 
</EE> 
<?php 
} 
2 


$row = mysqli_fetch_assoc($result); 语 句 直接 从 $result 结果 中 取得 一 行 , 并 且 以 关联 数组 的 形式 
返回 给 $row。 由 于 获得 的 是 关联 数组 ， 所 以 在 读 取 数 组 元 素 的 时 候 要 通过 字段 名 称 确定 数组 元 素 。 


19.3.8 获取 结果 集中 的 记录 作为 对 象 
使 用 mysqli_fetch_object() 函 数 从 结果 中 获取 一 行 记录 作为 对 象 。 语 法 格式 如 下 : 


mysqli_ fetch object (result); 


【 例 19.7】〔 实 例文 件 : ch19\19.7.php) 


<?php 
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while(Srow = mysqli fetch _ object (Sresult)) { // 逐 行 获取 结果 集中 的 记录 
> 
<tr> 
<td><?php echo $row->Id ?></td> <!-- 获取 当前 行 “Id” 字 段 值 --> 
<td><?php echo Srow->Name ?></td> <!-- 获取 当前 行 “Name” 字 段 值 --> 
<td><?php echo $row->Age ?></td> <!-- 获取 当前 行 “Age” 字 段 值 --> 
<td><?php echo $row->Gender ?></td> <!-- 获取 当前 行 “Gender ”字段 值 --> 
<td><?php echo $row->Info ?></td> <!-- 获取 当前 行 “Info” 字 段 值 --> 
</tr> 
<?php 
| 
?> 


该 程序 的 整体 运行 结果 和 上 一 节 案 例 相 同 。 不 同 的 是 ， 这 里 的 程序 采用 了 对 象 和 对 象 属性 的 
表示 方法 。 但 是 最 后 输出 的 数据 结果 是 相同 的 。 
19.3.9 使 用 mysqli_fetch_array() 函 数 获取 结果 集 记录 

mysqli_fetch_array 0 函数 的 语法 格式 如 下 : 

mysqli fetch array (result[,resuilt type]) 


参数 resuilt_type 是 可 选 参数 ， 表 示 一 个 常量 ， 可 以 选择 MYSQL ASSOC (关联 数组 ) ， 
MYSQL NUM (数字 数组 ) 和 MYSQL_BOTH (二 者 兼 有 ) ， 本 参数 的 默认 值 为 MYSQL_BOTH。 


【 例 19.8】 实 例文 件 : ch19\19.8.php) 


<?php 
while($row = mysqli fetch array ($result)) { // 逐 行 获取 结果 集中 的 记录 
2 
<tr> 
<td><?php echo $row["Id"] ?></td> // 使 用 字段 名 做 索引 显示 字段 值 
<td><?php echo $row["1"] ?></td> // 使 用 数字 做 索引 显示 字段 值 


<td><?php echo $row["Age"] ?></td> 
<td><?php echo $row["3"] ?></td> 
<td><?php echo $row["Info"] ?></td> 

</tr> 

<?php 

} 


2> 


19.3.10 ”使 用 mysqli_free_result() 函 数 释 放 资 源 
释放 资源 的 函数 为 mysqli_free_result()， 函 数 的 格式 为 : 
mysqli_free_result (SQL 请 求 所 返回 的 数据 库 对 象 ) 
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A 在 一 切 操作 都 基本 完成 以 后 ， 程 序 通过 mysqli_free_result($result); 语 句 释 放 了 SQL 请 求 所 返 
回 的 对 象 $result 所 占用 的 资源 。 


19.4 ”实战 演练 1 一 一 PHP 操作 数据 库 


下 面 以 通过 Web 向 user 数据 库 请 求 数据 为 例 , 介绍 如 何 使 用 PHP 函数 处 理 MySQL 数据 库 数 
据 。 具体 步骤 如 下 。 


在 网 址 主 目录 下 创建 phpmysql 文件 夹 。 
因 在 phpmysql 文件 夹 下 建立 文件 htmlform.html， 输 入 如 下 代码 。 


<html> 
<head> 
<title>Finding User</title> 
</head> 
<body> 
<h2>Finding users from mysql database.</h2> 
<form action="formhandler.php" method="post"> 
Fill user name: 
<input name="username" type="text" size="20"/> <br /> 
<input name="submit" type="submit" value="Find"/> 
</form> 
</body> 
</html> 


贺 在 phpmysql 文 件 夹 下 建立 文件 formhandler.php， 输 入 如 下 代码 。 


<html> 
<head> 
<title>User found</title> 
</head> 
<body> 
<h2>User found from mysql database.</h2> 
<?php 
$username = $_POST['username']; 
if(!$username){ 
echo "Error: There is no data passed."; 
exit; 


} 


if(!get magic quotes gpc()){ 
$username = addslashes ($username); 
@ $db = mysqli connect ('localhost','root','753951','adatabase'); 


if(mysqli connect errno()){ 
echo "Error: Could not connect to mysql database."; 


exit; 

} 

$q = "SELECT * FROM user WHERE name = '".S$username."'"; 
$result mysqli query ($db, $q); 


$rownum = mysqli num rows($result); 
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for($i=0; $i<$rownum; $i++){ 
$row = mysqli fetch assoc($result); 
echo "Id:".$rowl"id']:."<br /> 
echo "Name:".Srow['name']."<br />"; 
echo "Age:".$row['age']."<br />"; 
echo "Gender:".S$row['gender']."<br />"; 
echo mEnfor vroul AnFon ll <br /Sn 

| 


mysqli free result ($result); 
mysqli close($db); 

?> 

</body> 

</html> 


加 运行 htmlform.html， 结 果 如 图 19-8 所 示 。 








加 
Bee BD- Box)|B eng use Me 
Xen WR SB FRR TR wo 
Finding users from mysql database. 
Fill user nane; 
| 
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图 19-8 htmlform.html 页 面 
加 在 输入 框 中 输入 用 户 名 lilili， 单 击 find 按钮 ， 页 面 跳 转 至 formhandler.php， 并 且 返 回 请 
求 结果 ， 如 图 19-9 所 示 。 
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图 19-9 formhandlerphp 页 面 


19.5 ”实战 演练 2 一 一 使 用 insert 语句 动态 添加 用 户 信息 


在 前 面 的 实例 中 , 程序 通过 form 查询 了 特定 用 户 名 的 用 户 信息 。 下 面 将 使 用 其 他 SQL 语句 实 
现 PHP 的 数据 请 求 。 

下 面 通用 使 用 adatabase 的 user 数据 库 表 格 ， 添 加 新 的 用 户 信息 。 具 体操 作 步 骤 如 下 。 

在 phpmysql 文件 夹 下 建立 文件 insertform.html， 并 且 输 入 代码 如 下 。 


<html> 
<head> 
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<title>Adding User</title> 
</head> 
<body> 
<h2>Adding users to mysql database.</h2> 
<form action="formhandler.php" method="post"> 
Select gender: 
<select name="gender"> 
<option value="male">man</option> 
<option value="female">woman</option> 
</select><br /> 
Fill user name: 
<input name="username" type="text" size="20"/> <br /> 
Fill user age: 
<input name="age" type="text" size="3"/> <br /> 
Fill user info: 
<input name="info" type="text" size="60"/> <br /> 
<input name="submit" type="submit" value="Add"/> 
</form> 
</body> 
</html> 


四 在 phpmysql 文件 夹 下 建立 文件 insertformhandler.php， 并 且 输 入 代码 如 下 。 


<html> 
<head> 
<title>User adding</title> 
</head> 
<body> 
<h2>adding new user.</h2> 
<?php 
$username = $_POST['username']; 
$gender = $_POST['gender']; 
$age = $_POST['age']; 
$info = $ POST['info']; 
if(!$username and !$gender and !$age and !$info){ 
echo "Error: There is no data passed."; 
exit; 







h 

if(!$username or !S$gender or !$age or !$info){ 
echo "Error: Some data did not be passed."; 
exit; 

} 

if(!get magic quotes gpc()){ 
$username = addslashes ($username); 
$gender = addslashes (Sgender) ; 
$age = addslashes ($age); 
$info = addslashes ($info); 


@ $db = mysqli connect ('localhost','root','753951', '‘'adatabase'); 
if(mysqli connect errno()){ 
echo "Error: Could not connect to mysql database."; 
exit; 
上 
$q = "INSERT INTO user( Name, Age, Gender, Info) 
VALUES ('$username', $age,'$gender', '$info')"; 
if( !mysqli query ($db, $q)){ 
echo "no new user has been added to database.™"; 
}else{ 
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echo "New user has been added to database."; 
] 7 
mysqli close($db) 
这 
</body> 
</html> 


辆 运行 insertform.html， 运 行 结果 如 图 19-10 所 示 。 
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图 19-10 insertform.html 运行 结果 


加 单 击 Add 按钮 ， 页 面 跳 转 至 insertformhandler.php， 并 且 返 回信 息 结构 ， 如 图 19-11 所 示 。 
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adding new user. 


New user has been added to database. 











图 19-11 insertformhandler.php 页 面 


【案例 分 析 】: 

这 时 数据 库 user 表格 中 ， 就 被 添加 了 一 个 新 的 元 素 。 

(1) insertform.html 文件 中 ， 建 立 了 user 表格 中 除 id 外 每 个 字段 的 信息 输入 框 。 

(2) insertformhandler.php 文件 中 ， 建 立 MySQL 连接 ， 生 成 连接 对 象 等 操作 都 与 前 面 的 程序 
相同 。 只 是 改变 了 SQL 请 求 语句 的 内 容 为 $q = "INSERT INTO user( Name, Age, Gender, Info) 
VALUES ('$username',$age,'$gender', '$info')"; 插 入 语句 。 

(3) 其 中 Name、Gender、Info 字段 为 字符 串 型 ， 所 以 $username'、'$gender 、'$info' 3 个 变量 


要 以 字符 串 形式 加 入 。 
19.6 ”实战 演练 3 一 一 使 用 select 语句 查询 数据 信息 


本 案例 讲述 如 何 使 用 select 语句 查询 数据 信息 。 具 体操 作 步 又 如 下 。 
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在 phpmysql 文件 夹 下 建立 文件 selectform.htm1， 并 且 输 入 代码 如 下 。 


<html> 
<head> 
<title>Finding User</title> 
</head> 
<body> 
<h2>Finding users from mysql database.</h2> 
<form action="selectformhandler.php" method="post"> 
Select gender: 
<select name="gender"> 
<option value="male">man</option> 
<option value="female">woman</option> 
</select><br /> 
<input name="submit" type="submit" value="Find"/> 
</form> 
</body> 
</html> 


贺 在 phpmysql 文件 夹 下 建立 文件 selectformhandler.php， 并 且 输 入 代码 如 下 。 


<html> 
<head> 
<title>User found</title> 
</head> 
<body> 
<h2>User found from mysql database.</h2> 
<?php 
$gender = $ POST['gender']; 
if(!$gender){ 
echo "Error: There is no data passed."; 
exit; 





} 
if(!get magic quotes gpc()){ 
$gender = addslashes ($gender); 
} 
@ $db = mysqli connect ('localhost','root','753951'); 
mysqli select dbl($db,'adatabase'); 
if(mysqli connect errno()){ 
echo "Error: Could not connect to mysql database."; 
exit; 
$q = "SELECT * FROM user WHERE gender = '".$gender."'"; 
$result = mysqli query ($db, $q); 
$rownum = mysqli num rows($result); 
for ($i=0; $i<$rownum; $i++){ 
$row = mysqli fetch assoc($result); 
echo "Id:".$row[l"id"]. "<br /> 
echo "Name:".$row['name']."<br />"; 
echo "Age:".S$row['age']."<br />"; 
echo "Gender:".Srow['gender'] ."<br />"; 
Soho "Tnfoim .Srow[l nfo <br /> 
} 
mysqli free result ($result); 
mysqli close($db); 





LT 





3 
</body> 
</html> 
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因 运行 selectform.html， 结 果 如 图 19-12 所 示 。 
单 击 Find 按钮 ， 页 面 跳 转 至 selectformhandler.php， 并 且 返 回信 息 ， 如 图 19-13 所 示 。 
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Finding users from mysql database. 
图 19-12 ”selectform.html 运行 结果 图 19-13 。 selectformhandlerphp 页 面 
这 样 程 序 就 给 出 了 所 有 gender 为 female 的 用 户 信息 。 
19.7 ”高 手 私房 菜 


技巧 1: 修改 php.ini 文件 后 仍然 不 能 调用 MySQL 数据 库 怎么 办 ? 

有 了 时候 修 改 php.ini 文件 不 能 保证 一 定 可 以 加 载 MySQL 函数 库 。 此 时 如 果 使 用 phpinfo() 函 数 
不 能 显示 MySQL 的 信息 ， 说 明 配 置 失 败 了 。 重 新 按照 19.2 节 的 内 容 检查 配置 是 否 正确 ， 如 果 正 
确 , 则 把 PHP 安装 目录 下 的 libmysql.dll 库 文件 直接 复制 到 系统 的 system32 目录 下 , 然后 重新 启动 
IIS 或 APACHE， 最 好 再 次 使 用 phpinfo() 进 行 验证 ， 即 可 看 到 MySQL 信息 ， 表 示 此 时 已 经 配置 成 
功 。 

技巧 2: 为 什么 尽量 省 略 MySQL 语句 中 的 分 号 ? 

在 MySQL 语句 中 ， 每 一 行 的 命令 都 使 用 分 号 〈; ) 作为 结束 ， 但 是 ， 当 一 行 MySQL 被 插入 
在 PHP 代码 中 时 ， 最 好 把 后 面 的 分 号 省 略 掉 。 这 主要 是 因为 PHP 也 是 以 分 号 作为 一 行 的 结束 的 ， 
额外 的 分 号 有 时 会 让 PHP 的 语法 分 析 器 搞 不 明白 ， 所 以 还 是 省 略 掉 的 好 。 在 这 种 情况 下 ， 虽 然 省 
略 了 分 号 ， 但 是 PHP 在 执行 MySQL 命令 时 会 自动 加 上 。 

另外 还 有 不 要 加 分 号 的 情况 。 当 用 户 想 把 字段 竖 着 排列 显示 下 来 ， 而 不 是 像 通 常 那样 横着 排 
列 时 ， 可 以 用 G 来 结束 一 行 SQL 语句 ， 这 时 就 用 不 上 分 号 了 ， 例 如 : 

SELECT * FROM paper WHERE USER_ID =1G 


19.8 经典 习题 
(1) 在 Windows 系统 下 配置 PHP。 


(2) 编写 连接 MySQL 数据 库 的 代码 。 
(3) 操作 test 数据 库 下 的 fruits 数据 表 ， 包 括 查 询 、 插 入 、 更 新 和 删除 操作 。 


第 20 章 新 闻 发 布 系统 数据 库 设 计 


MySQL 数据 库 的 使 用 非常 广泛 ， 很 多 的 网 站 和 管理 系统 使 用 MySQL 数据 库存 储 数据 。 本 章 
节 主 要 讲述 新 闻 发 布 系统 的 数据 库 设 计 过 程 。 通过 本 章节 的 学 习 , 读者 可 以 在 新 闻 发 布 系统 的 设计 
过 程 中 学 会 如 何 使 用 MySQL 数据 库 。 
本 章 学 习 目 标 
@ 了 解 新 闻 发 布 系统 的 概述 
熟悉 新 闻 发 布 系统 的 功能 
掌握 如 何 设计 新 闻 发 布 系统 的 表 
掌握 如 何 设计 新 闻 发 布 系统 的 索引 
掌握 如 何 设计 新 闻 发 布 系统 的 视图 
掌握 如 何 设计 新 闻 发 布 系统 的 触发 器 


20.1 系统 概述 


本 章 介绍 的 是 一 个 小 型 新 闻 发 布 系统 ， 管 理 员 可 以 通过 该 系统 发 布 新 闻 信息 ， 管 理 新 闻 信息 。 
一 个 典型 的 新 闻 发 布 系统 网 站 至 少 应 包含 新 闻 信 息 管 理 、 新 闻 信 息 显示 和 新 闻 信息 查询 3 种 功能 。 

新 闻 发 布 系统 所 要 实现 的 功能 具体 包括 : 新 闻 信 息 添 加 、 新 闻 信 息 修改 、 新 闻 信 息 删 除 、 显 
示 全 部 新 闻 信 息 、 按 类 别 显示 新 闻 信 息 、 按 关键 字 查询 新 闻 信 息 、 按 关键 字 进 行 站 内 查询 。 

本 站 为 一 个 简单 的 新 闻 信 息 发 布 系统 ， 该 系统 具有 以 下 特点 。 

@ 实用: 系统 实现 了 一 个 完整 的 信息 查询 过 程 。 

@ 简单 易 用 : 为 使 用 户 尽 快 掌握 和 使 用 整个 系统 ， 系 统 结构 简单 但 功能 齐全 ， 简 洁 的 页 面 

设计 使 操作 起 来 非常 简便 。 

@ 代码 规范 : 作为 一 个 实例 ， 文 中 的 代码 规范 简洁 、 清 晰 易 懂 。 

本 系统 主要 用 于 发 布 新 闻 人 信息、 管理 用 户 、 管 理 权限 、 管 理 评论 等 功能 。 这 些 信息 的 录入 、 
查询 、 修 改 和 删除 等 操作 都 是 该 系统 重点 解决 的 问题 。 

本 系统 主要 功能 包括 以 下 几 点 : 

(1) 具有 用 户 注册 及 个 人 信息 管理 功能 。 

(2) 管理 员 可 以 发 布 新 闻 、 删 除 新 闻 。 

(3) 用 户 注册 后 可 以 对 新 闻 进 行 评论 、 发 表 留言 。 

(4) 管理 员 可 以 管理 留言 和 对 用 户 进行 管理 。 
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20.2 系统 功能 


新 闻 发 布 系统 分 为 5 个 管理 部 分 ， 即 用 户 管理 、 管 理 员 管理 、 权 限 管理 、 新 闻 管理 和 评论 管 
理 。 本 系统 的 功能 模块 如 图 20-1 所 示 。 
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图 20-1 系统 功能 模块 图 
图 20-1 中 模块 的 详细 介绍 如 下 。 


(1) 用 户 管理 模块 : 实现 新 增 用 户 ， 查 看 和 修改 用 户 信息 功能 。 

(2) 管理 员 管理 模块 :实现 新 增 管理 员 ， 查 看 、 修 改 和 删除 管理 员 信息 功能 。 

(3) 权限 管理 模块 : 实现 对 管理 员 、 对 管理 的 模块 和 管理 的 评论 赋 权 功能 。 

(4) 新 闻 管 理 模块 : 实现 有 相关 权限 的 管理 员 对 新 闻 的 增加 、 查 看 、 修 改 和 删除 功能 。 

(5) 评论 管理 模块 : 实现 有 相关 权限 的 管理 员 对 评论 的 审核 和 删除 功能 。 

通过 本 节 的 介绍 ， 读 者 对 这 个 新 闻 发 布 系统 的 主要 功能 有 一 定 的 了 解 ， 下 一 节 会 向 读者 介绍 
本 系统 所 需要 的 数据 库 和 表 。 


20.3 ”数据库 设计 和 实现 


数据 库 设 计 是 开发 管理 系统 的 最 重要 的 一 个 步 又 。 如 果 数据 库 设计 得 不 够 合理 ， 将 会 为 后 续 
的 开发 工作 带 来 很 大 的 麻烦 。 本 节 为 读者 介绍 新 闻 发 布 系统 的 数据 库 开发 过 程 。 

数据 库 设计 时 要 确定 设计 哪些 表 、 表 中 包含 哪些 字段 、 字 段 的 数据 类 型 和 长 度 。 通 过 本 章 
节 的 学 习 ， 读 者 可 以 对 MySQL 数据 库 的 知识 有 个 全 面 的 了 解 。 


20.3.1 设计 表 
本 系统 所 有 的 表 都 放 在 webnews 数据 库 下 。 创 建 和 选择 webnews 数据 库 的 SQL 代码 如 下 : 
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CREATE DATABASE webnews; 


USE webnews; 


在 这 个 数据 库 下 总 共存 放 9 张 表 ， 分 别 是 user、admin、roles、news、category、comment、 


admin Roles、news_Comment 和 users Comment。 
1. user 表 


user 表 中 存储 用 户 ID、 用 户 名 、 密 码 和 用 户 Email 地 址 ， 所 以 user 表 设 计 了 4 个 字段 。user 
表 每 个 字段 的 信息 如 表 20-1 所 示 。 


表 20-1 user 表 的 内 容 
列 名 数据 类 型 允许 NULL 值 说 明 


[uD mr | 用 户 编号 
VARCHARO0) 用 户 名 称 


VARCHAR(20) 用 户 密码 
VARCHAR(20) 用 户 Email 
根据 表 20-1 的 内 容 创 建 user 表 。 创 建 user 表 的 SQL 语句 如 下 : 
CREATE TABLE user( 
userID INT PRIMARY KEY UNIQUE NOT NULL, 
userName VARCHAR(20) NOT NULL, 
userPassword VARCHAR(20) NOT NULL, 
userEmail VARCHAR(20) NOT NULL 
De 


2. admin 表 
管理 员 信息 表 (admin) 主要 用 来 存放 用 户 账 号 信息 ， 如 表 20-2 所 示 。 
表 20-2 admin 表 的 内 容 
列 名 数据 类 型 允许 NULL 值 说 明 


ammp JJm | 否 |gaass | 








根据 表 20-2 的 内 容 创建 admin 表 。 创 建 admin 表 的 SQL 语句 如 下 : 
CREATE TABLE admin( 
adminID INT PRIMARY KEY UNIQUE NOT NULL, 
adminName VARCHAR(20) NOT NULL, 
adminPassword VARCHAR(20) NOT NULL 
) 7 


。344 。 
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3. roles 表 
权限 信息 表 (roles) 主要 用 来 存放 权限 信息 ， 如 表 20-3 所 示 。 
表 20-3 roles 权限 信息 表 的 内 容 








数据 类 型 允许 NULL 值 
roleID INT 否 权限 编号 
| roleName VARCHAR(20) 百 权限 名 称 





根据 表 20-3 的 内 容 创 建 roles 表 。 创 建 roles 表 的 SQL 语句 如 下 : 
CREATE TABLE roles( 
roleID INT PRIMARY KEY UNIQUE NOT NULL, 
roleName VARCHAR(20) NOT NULL 
); 
4. news 表 
新 闻 信息 表 (news) 主要 用 来 存放 新 闻 信息 ， 如 图 20-4 所 示 。 
表 20-4 news 新 闻 信息 表 的 内 容 


数据 类 型 允许 NULL 值 说 明 
新 闻 


下 
newsTitle VARCHAR(50) 在 新 闻 


newsContent 


新 闻 


newsRate 新 闻 








根据 表 20-4 的 内 容 创 建 news 表 。 创 建 news 表 的 SQL 语句 如 下 : 


CREATE TABLE news( 
newsID INT PRIMARY KEY UNIQUE NOT NULL, 
newsTitle VARCHAR(50) NOT NULL, 
newsContent TEXT NOT NULL, 
newsDate TIMESTAMP, 
newsDesc VARCHAR(50) NOT NULL, 
newsImagePath VARCHAR(50), 
newsRate INT NOT NULL, 
newsIsCheck BIT NOT NULL, 
newsIsTop BIT NOT NULL 
); 


> 
了 


标题 


新 闻 内 容 
newsDate 发 布 时 间 


描述 


newsImagePath 新 闻 图 片 路 径 


级 别 


newsIsCheck 新 闻 是 否 检 验 


newsIsTop ? 新 闻 是 


否 置 顶 
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5. category 表 
栏目 信息 表 (categroy) 主要 用 来 存放 新 闻 栏 目 信息 ， 如 图 20-5 所 示 。 
表 20-5 category 栏目 信息 表 的 内 容 











数据 类 型 允许 NULL 值 
categroyID INT 否 栏目 编号 
| categroyName VARCHAR(50) 否 栏目 名 称 
| categroyDesc VARCHAR(50) 否 栏目 描述 





根据 表 20-5 的 内 容 创建 categroy 表 。 创 建 categroy 表 的 SQL 语句 如 下 : 


CREATE TABLE categroy ( 
CategoryID INT PRIMARY KEY UNIQUE NOT NULL, 
categoryName VARCHAR(50) NOT NULL, 
categoryDesc VARCHAR(50) NOT NULL 
) 7 


6. comment 表 
评论 信息 表 (comment) 主要 用 来 存放 新 闻 评 论 信息 ， 如 图 20-6 所 示 。 
表 20-6 comment 评论 信息 表 的 内 容 
列 名 数据 类 型 2 NULL 值 说 明 


VARCHAR(S0) 位 目标 
VARCHARGS0) 
DATETIME as | 栏目 时 间 


根据 表 20-6 的 内 容 创建 comment 表 。 创 建 comment 表 的 SQL 语句 如 下 : 


CREATE TABLE comment ( 
commentID INT PRIMARY KEY UNIQUE NOT NULL, 
commentTitle VARCHAR(50) NOT NULL, 
commentContent TEXT NOT NULL, 
commentDate DATETIME 
); 





7. admin_Roles 表 
管理 员 _ 权 限 表 (admin_Roles) 主要 用 来 存放 管理 员 和 权限 的 关系 ， 如 图 20-7 所 示 。 
表 20-7 admin_Roles 管理 员 _ 权 限 表 的 内 容 
列 名 数据 类 型 允许 NULL 值 说 明 
ap mm 上 sanimi | 
pe | ee 生理 号 


EE 
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根据 表 20-7 的 内 容 创建 admin_ Roles 表 。 创 建 admin_ Roles 表 的 SQL 语句 如 下 : 


CREATE TABLE admin Roles ( 
aRID INT PRIMARY KEY UNIQUE NOT NULL, 
adminID INT NOT NULL, 
roleID INT NOT NULL 
J 


8. news_Comment 表 
新 闻 _ 评 论 表 (news_Comment) 主要 用 来 存放 新 闻 和 评论 的 关系 ， 如 图 20-8 所 示 。 
表 20-8 新 闻 _ 评 论 表 
列 名 数据 类 型 允许 NULL 值 说 明 


seemp | ET 


mr 
[mmop nr se | 


根据 表 20-8 的 内 容 创 建 news_Comment 表 。 创 建 news_Comment 表 的 SQL 语句 如 下 : 


CREATE TABLE news Comment ( 
nCommentID INT PRIMARY KEY UNIQUE NOT NULL, 
newsID INT NOT NULL, 
commentID INT NOT NULL 
) 7 





9. users_Comment 表 
用 户 评论 表 (users_Comment) 主要 用 来 存放 用 户 和 评论 的 关系 ， 如 图 20-9 所 示 。 
表 20-9 新 闻 _ 评 论 表 








列 名 数据 类 型 允许 NULL 值 说 明 
userID INT 否 用 户 编号 
| commentID | INT 否 | 评论 编号 | 





根据 表 20-8 的 内 容 创 建 users_ Comment 表 。 创 建 users_Comment 表 的 SQL 语句 如 下 : 


CREATE TABLE news Comment ( 
uCID INT PRIMARY KEY UNIQUE NOT NULL, 
userID INT NOT NULL, 
commentID INT NOT NULL 
ys 


创建 完成 后 ， 可 以 使 用 DESC 语句 查看 表 的 基本 结构 ， 也 可 以 通过 SHOW CREATE TABLE 
语句 查看 表 的 详细 信息 。 
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20.3.2 ”设计 索引 

索引 是 创建 在 表 上 的 ， 是 对 数据 库 中 一 列 或 者 多 列 的 值 进行 排序 的 一 种 结构 。 索 引 可 以 提高 
查询 的 速度 。 新 闻 发 布 系统 需要 查询 新 闻 的 信息 ， 这 就 需要 在 某 些 特定 字段 上 建立 索引 ， 以 便 提 高 
查询 速度 。 

1. 在 news 表 上 建立 索引 

新 闻 发 布 系统 中 需要 按照 newsTitle 字段 、newsDate 字段 和 newsRate 字段 查询 新 闻 信 息 。 在 
本 书 的 前 面 的 章节 中 介绍 了 几 种 创建 索引 的 方法 。 本 小 结 将 使 用 CREATE INDEX 语句 和 ALTER 
TABLE 语句 创建 索引 。 

下 面 使 用 CREATE INDEX 语句 在 newsTitle 字段 上 创建 名 为 index_new_title 的 索引 。SQL 语 

名 如 下 : 

CREATE INDEX index new title ON news (newsTit1le) 7 

然后 ， 使 用 CREATE INDEX 语句 在 newsDate 字段 上 创建 名 为 index_new_date 的 索引 。SQL 
语句 如 下 : 

CREATE INDEX index new date ON news (newsDate); 

最 后 ,使 用 ALTER TABLE 语句 在 newsRate 字段 上 创建 名 为 index_new_rate 的 索引 。SQL 语 
句 如 下 : 

ALTER TABLE news ADD INDEX index new rate (newsRate); 

2. 在 categroy 表 上 建立 索引 

新 闻 发 布 系统 中 需要 通过 栏目 名 称 查 询 该 栏目 下 的 新 闻 ， 因 此 需要 在 这 个 字段 上 创建 索引 。 
创建 索引 的 语句 如 下 : 

CREATE INDEX index_categroy_name ON categroy (categroyName) 

代码 执行 完成 后 ， 读 者 可 以 使 用 SHOW CREATE TABLE 语句 查看 categroy 表 的 详细 信息 。 

3. 在 comment 表 上 建立 索引 


新 闻 发 布 系统 需要 通过 commentTitle 字段 和 commentDate 字段 查询 评论 内 容 。 因 此 可 以 在 这 
两 个 字段 上 创建 索引 。 创 建 索引 的 语句 如 下 : 


CREATE INDEX index comment title ON comment (commentTitle); 
CREATE INDEX index comment date ON comment (commentDate); 


代码 执行 完成 后 ， 读 者 可 以 通过 SHOW CREATE TABLE 语句 查看 comment 表 的 结构 。 
20.3.3 设计 视图 


视图 是 由 数据 库 中 一 个 表 或 者 多 个 表 导 出 的 虚拟 表 。 其 作用 是 方便 用 户 对 数据 的 操作 。 在 这 
个 新 闻 发 布 系统 中 ， 也 设计 了 一 个 视图 改善 查询 操作 。 
在 新 闻 发 布 系统 中 ， 如 果 直接 查询 news_Comment 表 ， 显 示 信 息 时 会 显示 新 闻 编 号 和 评论 编号 。 
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这 种 显示 不 直观 ， 为 了 以 后 查询 方面 ， 可 以 建立 一 个 视图 news_view。 这 个 视图 显示 评论 编号 、 新 闻 
号 、 新 闻 级 别 、 新 闻 标 题 、 新 闻 内 容 和 新 闻 发 布 时 间 。 创 建 视图 news_view 的 SQL 代码 如 下 : 
CREATE VIEW news view 
RS SELECT c.commentID,n.newsID,n.newsRate,n.newsTitle,n.newsContent,n.newsDate 


FROM news_Comment cr news n 
WHERE news_Comment .newsID=news .newSsID; 


SQL 语句 中 给 每 个 表 都 取 了 别名 ，news_Comment 表 的 别名 为 c; news 表 的 别名 为 n， 这 个 视 
图 从 这 两 个 表 中 取出 相应 的 字段 。 视 图 创建 完成 后 ， 可 以 使 用 SHOW CREATE VIEW 语句 查看 
news_view 视图 的 详细 信息 。 


20.3.4 设计 触发 器 


触发 器 是 由 INSERT、UPDATE 和 DELETE 等 事件 来 触发 某 种 特定 的 操作 。 满 足 触发 器 的 触 
发 条 件 时 , 数据 库 系统 就 会 执行 触发 器 中 定义 的 程序 语句 。 这 样 做 可 以 保证 某 些 操作 之 间 的 一 致 性 。 
为 了 使 新 闻 发 布 系统 的 数据 更 新 更 加 快速 和 合理 ， 可 以 在 数据 库 中 设计 几 个 触发 器 。 

1. 设计 UPDATE 触发 器 

在 设计 表 时 ，news 表 和 news_Comment 表 的 newsID 字段 的 值 是 一 样 的 。 如 果 news 表 中 的 
newsID 字段 的 值 更 新 了 , 那么 news_Comment 表 中 的 newsID 字段 的 值 也 必须 同时 更 新 。 这 可 以 通 
过 一 个 UPDATE 触发 器 来 实现 。 创 建 UPDATE 触发 器 update_newsID 的 SQL 代码 如 下 : 


DELIMITER && 
CREATE TRIGGER update newsID AFTER UPDATE 
ON news FOR EACH ROW 
BEGIN 
UPDATE news_Comment SET newsID=NEW. newsID 
END 
&& 
DELIMITER ; 


其 中 NEW. newsID 表示 news 表 中 更 新 的 记录 的 newsID 值 。 


2. 设计 DELETE 触发 器 


如 果 从 user 表 中 删除 一 个 用 户 的 信息 ， 那 么 这 个 用 户 在 users_Comment 表 中 的 信息 也 必须 同 
时 删除 。 这 也 可 以 通过 触发 器 来 实现 。 在 user 表 上 创建 delete_user 触发 器 ， 只 要 执行 DELETE 操 
作 ， 那 么 就 删除 users_Comment 表 中 相应 的 记录 。 创 建 delete_user 触发 器 的 SQL 语句 如 下 : 


DELIMITER && 
CREATE TRIGGER delete user AFTER DELETE 
ON user FOR EACH ROW 
BEGIN 
DELETE FROM users Comment WHERE UserID=OLD. userID 
END 
&& 
DELIMITER ; 


其 中 ，OLD. userID 表示 新 删除 的 记录 的 userID 值 。 
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PHP 与 MySQL 的 结合 是 开发 Web 网 站 的 黄金 搭档 。 本 章 将 以 论坛 网 站 的 开发 为 例 进行 讲解 。 
论坛 网 站 的 开发 具有 网 站 开发 的 代表 性 ， 通 过 本 章 的 学 习 ， 读 者 可 以 掌握 PHP+MySQL 开发 网 站 
的 常用 知识 和 技巧 。 

本 章 学 习 目标 

@ 熟悉 网 站 的 需求 分 析 

@ 热 秋 数据 库 分 析 

@ ”掌握 论坛 的 实现 过 程 














21.1 网 站 的 需求 分 析 

在 开发 网 站 之 前 ， 首 先 需 要 分 析 网 站 的 需求 ， 包 括 网 站 需求 分 析 和 网 站 的 功能 模板 分 析 。 
21.1.1 需求 分 析 

需求 分 析 是 论坛 网 站 开发 的 必要 环节 ， 下 面 分 析 论坛 网 站 的 需求 如 下 。 

(1) 论坛 的 游客 可 以 注册 、 登 录 网 站 和 浏览 主题 。 

(2) 论坛 的 普通 注册 用 户 拥 有 浏览 ， 发 表 主 题 、 回 复 主题 、 修 改 自 己 的 个 人 资料 、 查 询 主题 、 
修改 自己 发 布 或 回复 的 帖子 等 功能 。 

(3) 版 主 对 版 块 的 管理 功能 ， 包 括 对 帖子 的 主要 操作 有 : 查询 主题 、 置 项 、 加 精 、 移 动 、 编 
辑 和 删除 ， 对 用 户 的 操作 有 : 禁止 发 言 和 删除 id， 对 版块 的 操作 主要 包括 发 布 版 块 和 广告 。 

(4) 系统 管理 员 对 版 块 的 操作 有 : 建立 、 修 改 和 删除 版 块 ， 对 用 户 的 操作 有 : 禁止 发 言 和 删 
除 id， 对 帖子 的 主要 操作 有 : 查询 主题 、 置 项 、 加 精 、 移 动 、 编 辑 和 删除 ， 对 论坛 的 操作 有 : 开 
放 或 关闭 会 员 注册 功能 。 
21.1.2 ”网 站 功能 模块 分 析 

网 站 主要 功能 模块 如 下 。 

(1) 会 员 注册 模块 :新 会 员 注册 ， 提 供 会 员 信 息 ， 检 验 会 员 信息 的 有 效 性 ， 并 将 会 员 信息 持 
久 化 。 

(2) 会 员 登 录 模 块 : 提供 用 户 凭 证， 验证 用 户 信息 ， 基 于 角色 授权 。 

(3) 会 员 管理 模块 : 管理 员 由 系统 初始 化 分 配 ， 管 理 员 可 以 对 会 员 信息 进行 部 分 更 改 ， 主 要 
包括 用 户 角 色调 整 、 版 主 调整 、 删 除 会 员 等 。 

(4) 论坛 版 块 管理 模块 : 管理 员 可 以 添加 、 删 除 、 调 整 、 置 项 、 隐 藏 论坛 版 块 。 

(5) 帖子 管理 模块 : 管理 员 可 以 对 所 有 帖子 进行 转移 、 置 项 、 删 除 等 操作 ， 版 主 可 以 对 本 版 
块 帖 子 进行 置顶 、 删 除 等 操作 。 
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(6) 帖子 发 表 模块 : 用 户 可 以 在 其 权限 允许 的 版 块 内 发 表 帖子 。 

(7) 帖子 回复 模块 : 用户 可 以 对 其 权限 允许 的 主题 发 表 回复 。 

(8) 帖子 浏览 模块 : 用 户 可 以 浏览 所 有 可 见 的 帖子 。 

(9) 帖子 检索 模块 : 注册 用 户 可 以 提供 标题 关键 字 检 索 可 见 的 主题 帖 ， 并 可 以 查看 自己 发 表 
或 回复 的 帖子 。 





21.2 数据库 分 析 
分 析 完 网 站 的 功能 后 ， 下 面 开始 分 析 数 据 库 的 逻辑 结构 并 建立 数据 表 。 


21.2.1 分 析 数 据 库 


本 论坛 的 数据 库 名 称 为 bbs_data， 共 有 5 个 数据 表 ， 即 manage_user info、user_info、 
father_ module_ info、son_module_ info、note _info。 各 个 数据 表 之 间 的 逻辑 关系 如 图 21-1 所 示 。 











son_module info user_info 


图 21-1 数据 表 的 逻辑 关系 图 











21.2.2 ”创建 数据 表 
分 析 数 据 库 的 结构 后 ， 即 可 创建 数据 表 ， 各 个 数据 表 如 表 21-1~ 表 21-5 所 示 。 
表 21-1 manage_user_info (管理 用 户 信息 数据 表 ) 
类 





char(16) 管理 用 户 登录 名 
| user pw, char(16) | 








表 21-2 user_info (用 户 信 息 数据 表 ) 
类 型 字段 意义 




































1 

3 user pw char(16) 

4 | timel datetime 注册 时 间 

5 | time2 datetime 最 后 登录 时 间 
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表 21-3 father_module_info 〈 父 版 块 信息 数据 表 ) 
编号 字段 名 E34 字段 意义 


[1 | 
2 module name char(66) 版 块 名 称 2 
3 show_order int 显示 序号 
表 21-4 son_module_info( 子 版 块 信息 数据 表 ) 
编号 字段 名 类 型 字段 意义 


















备注 

id 

BS 隶属 的 父 版 块 的 id 同 father module info 中 的 id 
4 module_cont 子 版 块 简介 

5 


user name i 发 帖 用 户 名 同 user info 中 的 user name 








表 21-5 note_info (发 帖 信息 数据 表 ) 
一 一 -一 一 一 注 


ET 隶属 的 子 版 块 的 id 
jupid |int | 回复 帖子 的 id 和 id 
Ee 帖子 标题 | | 


I 内容 
es 
[7 [username [char(16) | 发 帖 用 户 名 | 同 user info 中 的 user name | 
| 





21.3 ”论坛 的 代码 实现 
下 面 来 分 析 论坛 的 代码 是 如 何 实现 的 。 
21.3.1 数据库 连接 相关 文件 


主要 的 数据 库 连 接 相关 文件 如 下 。 
文件 mysqliinc 位 于 配套 素材 包 的 ch2linc\ 下 ， 主 要 用 于 自 编 连接 数据 库 、 服 务 器 、SQL 语句 
执行 函数 库 。 主 要 代码 如 下 。 
<?php 
class mysqlconn{ 
/ /连接 服务 器 、 数 据 库 以 及 执行 SQL 语句 的 类 库 
Public $database; 
Public $server username; 
Public $server userpassword; 
function mysqli () 

{ ”// 构 造 函 数 初始 化 所 要 连接 的 数据 库 
$this->server username="root"; 
$this->server userpassword=""; 
}//end mysqli () 
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function link($database) 
{ // 连 接 服务 器 和 数据 库 
// 设 置 所 有 连接 的 数据 库 
if ($database==""){ 
$this->database="bbs data"; 
}else{ 
$this->database=$database; 
| 
/ /连接 服务 器 和 数据 库 


if(@$id=mysqli connect ('localhost', $this->server username, $this->server us 
erpassword) ) { 
if(!mysqli select_db ($id,Sthis->database) ) { 
echo "数据 库 连 接 错 误 !!! "; 
exit; 
}elsel{ 
echo "服务 器 正在 维护 中 ， 请 稍 后 重 试 !!1! "; 
exit; 
} 
}//end link($database) 
function excu ($query) 
// 执 行 SQL 语句 
if($result=mysqli query ($query)){ 
return $result; 
}else{ 
echo "sql 语句 执行 错误 !!! 请 重 试 !! !"; 
exit; 
1 
} //end exec(S$query) 
} //end class mysql 
> 


文件 myfunction.inc 位 于 配套 素材 包 的 ch21\inc\ 下 ， 主 要 用 于 自 编 函 数 库 。 主 要 代码 如 下 。 
<?php 
class myfunction{ 


/L11111111111111/ 字 符 转 换 : 向 数据 库 中 插入 或 更 新 时 用 /11/11111111111111111111117/ 


function str tol($str) 


$str=str replace(" ","gnbsp;",$str); // 把 空格 替换 html 的 字符 串 空格 
$str=str_replace("<","g&lt;",$str); // 把 html 的 输出 标志 正常 输出 
$str=str_ replace(">","ggt;",$str); // 把 html 的 输出 标志 正常 输出 
$str=n12br ($str); // 把 回 车 替换 成 html 中 的 br 
return S$str; 


} 
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//A/LAAAAAAAAAAAAAAAA/ 由 子 版 块 的 id 返回 该 子 版 块 的 主题 数 /111111111111111111117/ 

function son module idtonote num($son module id){ 
$aa=new mysqlconn; 
saa >link( ms 
$query="select * from note info where module id='".$son module id."' 

and up_id="'0'"; 
$rst=$aa->excu ($query); 
return mysqli num rows($rst); 
} 
ORAM ERMA A ND DAA 


LLLLLL11L11111111111/ 由 子 版 块 的 id 返回 该 子 版 块 的 帖子 数 /11111111111111111117117/ 
function son module idtonote num2($son module id){ 
// 由 子 版 块 的 id 返回 该 子 版 块 的 主题 数 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info where module id='".$son module id."' 
and up_id="'0'"; 
$rst=$aa->excu ($query); 
$num=mysqli num rows ($rst); 
while ($note=mysqli fetch array($rst,MYSQL ASSOC)){ 
$query="select * from note info where up_ id='".$note['id']."' and 
module id="'0"'"; 
$rst=$aa->excu ($query); 
$numt=mysqli num rows($rst); 
} 
return $num; 
} 
LVLLVVV1VLL11V111111M1/ 由 子 版 块 的 id 输出 该 子 版 块 的 最 新 帖子 /1/1/1111111111111111171/ 
function son module idtolast note($son module id){ 
4/ 由 子 版 块 的 ia 输出 该 子 版 块 的 最 新 帖子 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info where module id='".$son module id."' 
order by time desc limit 0,1"; 
$rst=$aa->excu ($query); 
$note=mysqli _ fetch array ($rst,MYSQL ASSOC); 
$query2="select * from note info where id='".$note['up id']."'"; 
$rst2=$aa->excu ($query); 
$note2=mysqli fetch array($rst2,MYSQOL ASSOC); 
echo $note2['title']; 
echo "<br />"; 
echo $note['time']."é&nbsp;&nbsp;".S$note['user name']; 
} 
LLLLLLLLVL11111111111/ 由 子 版 块 的 id 输出 该 子 版 块 的 版 主 //111111111111111111111 
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function son module idtouser name($son module id){ 
// 由 子 版 块 的 id 输出 该 子 版 块 的 版 主 
$aa=new mysqlconn; 
Saa~>link(m ws 
$query="select * from son module info where id='".$son module id."'"; 
$rst=$aa->excu ($query); 
$module=mysqli fetch array($rst,MYSQL ASSOC); 


if ($module['user name']==""){ 
return "版 主 暂 缺 "; 
}elsef{ 


return $module['user name']; 


1ML11411111111/ 输 出 所 有 版 块 的 下 拉 列 表 ( 子 版 块 有 参数 ) /1V11111111111111111 
function son module list($son module id){ 
// 输 出 所 有 版 块 的 下 拉 列表 〈 子 版 块 有 参数 ) 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from father module info order by id"; 
$rst=$aa->excu ($query); 
echo “<select name=module id>"; 
while($father module=mysqli fetch array($rst,MYSQL ASSOC)){ 
echo "<option value=>".$father module['module name']."</option>"; 
$query="select * from son module info where father module id='". 
$father module['id']."' order by id "; 
$rst2=$aa->excu ($query); 
while($son module=mysqli fetch array ($rst2,MYSQL ASSOC)){ 
echo"<option 
value=".$son module['id'].">&nbsp;&nbsp;".$son module['module name']."</option>"; 
} 
1 
echo "</select>"; 
} 
LMMAVLVVLL111111111M1 /输出 父 版 块 的 下 拉 列 表 /WVA4WVVV1VWVV1W11111111111111111111 
function father module list($father module id)1{ 
// 输 出 父 版 块 的 下 拉 列 表 
$aa=new mysqlconn; 
$aa->link(""); 
echo “<select name=father module id>"; 
if ($father module id==""){ 
echo "<option selected> 请 选择 .. .</option>"; 
Yelsef 
$query="select from father module info where 
id='$father module id'"; 
$rst=$aa->excu ($query); 
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$father module=mysqli fetch array($rst,MYSQOL ASSOC); 
echo"<option 
value=". $father module['id'].">".$father module['module name']."</option>"; 
， 
$query="select * from father module info order by show order"; 
$rst=$aa->excu ($query); 
while($father module=mysqli fetch array($rst,MYSQL ASSOC)){ 
echo "<option 
value=". $father module['id'].">".$father module['module name']."</option>"; 
echo "</select>"; 
} 
LMUVVVLALLL111111111/ 由 帖子 的 id 返回 该 帖子 被 浏览 的 次 数 /1VVVV11111111111111171 
function note idtotimes ($note iqd){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info where id='".$note id."'"; 
$rst=$aa->excu ($query); 
$note=mysqli fetch array ($rst,MYSQL ASSOC) 了 
return $note[l'times']; 
} 
LMULVLLLLLL111111111/ 由 帖子 的 id 返回 该 帖子 的 标题 [1/1/11L111111111111111 
function note idtotitle($note id){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info where id='Snote_ id'"; 
$rst=$aa->excu ($query); 
$note=mysqli fetch array ($rst,MYSQL ASSOC); 
return $note['title']; 
} 
LMMLLLVLLL1111111111/ 由 帖子 的 id 返回 帖子 的 回复 数 111VVV1111111111111111/ 
function note idtonote num($note id){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info where up_id='".$note id."'"; 
$rst=$aa->excu ($query); 
$num=mysqli num rows ($rst); 
return Snum+17 
i 
LLMLVVL1V111111111/ 由 帖子 的 id 输出 帖子 的 最 后 回复 时 间 //1//1111111111117111 
function note idtolast time ($note id){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info where up id='$note id' order by time 
desc limit 0,1"; 
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S$rst=$aa->excu ($query); 
$note=mysqli fetch array ($rst,MYSQL ASSOC); 
echo $note['time']; 
} 
LMMLVVLL11L111111111/ 由 帖子 的 id 输出 帖子 的 最 后 回复 人 VAW1W1111111111111111/ 
function note idtolast user name ($note id){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info where up id='$note id' order by time 
dese limit 07;1"; 
$rst=$aa->excu ($query); 
$note=mysqli fetch array (Srst,MYSQL ASSOC); 
echo S$Snote[ 'user name']; 
} 
LAMMVVLVVLL11V11117V71 由 子 版 块 的 id 返回 其 父 版 块 的 名 称 /111V111111111111111117/1 
function son module idtofather name($son module iqd){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from son module info where id='$son module id'"; 
$rst=$aa->excu ($query); 
$module=mysqli fetch array($rst,MYSQL ASSOC); 
$query2="select 小 from father module info where 
id='$module [father module id]'"; 
$rst2=$aa->excu ($query2)，; 
$module2=mysqli _ fetch array ($rst2,MYSQL ASSOC); 
return $module2['module name']; 
} 
VLAVMVVM1111111111111/ 由 子 版 块 的 id 返回 本 版 块 的 名 称 /111111111111111111111/ 
function son module idtomodule name($son module id){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from son module info where id='".$son module id."'"; 
$rst=$aa->excu ($query); 
$module=mysqli fetch array($rst,MYSQOL ASSOC); 
return $module['module name']; 
LMMLLLLL1111111111111 所 有 帖子 的 总 数 111V1111111111111111111/ 
function note total num(){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from note info"; 
S$rst=$aa->excu ($query); 
return mysqli num rows (S$rst); 
} 
LLMLVLL1LL11111111111 所 有 会 员 的 总 数 111W111111111111111111717 
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function user total num(){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from user info"; 
$rst=$aa->excu ($query); 
return mysqli num rows ($rst); 
} 
LMM111111111111111111 所 有 会 员 的 总 数 11111V11111111111111111 
function last username (){ 
$aa=new mysqlconn; 
$aa->link(""); 
$query="select * from user info order by id desc limit 0,1"; 
$rst=$aa->excu ($query); 
$user=mysqli_ fetch array($rst,MYSQL ASSOC); 
return $user[ 'user name']; 
1 
LLMLMLL11111/ 分 页 函数 1111111111111111111/ 
function page ($query, $page_id, $add, $num per page){ 
// include "mysql.inc"; 
/1/11/111/ 使 用 方法 为 : 
/////// S$Smyf=new myfunction; 
/////// $query=""; 
/////// S$myf->page ($query, Spage_id, $add, $num per page); 
/////// S$bb=$aa->excu($query); 
$bb=new mysqlconn; 
global $query; // 声 明 全 局 变量 
sbb=->14nk(t"™")? 





$page_id=@$_GET['page id']; // 接 受 page_id 
el(spageBioee dl 
$page_id=1; 


$rst=$bb->excu ($query); 
$num=mysqli num rows (S$rst); 
if ($num==0){ 
echo "没有 查 到 相关 记录 或 没有 相关 回复 ! <br />"; 
} 
$page_num=ceil ($num/$num per page); 
for ($i=1;$i<=$page num;$i++){ 
echo "gnbsp; [<a href=?".$add."page id=".$i.">".$i."</a>]"; 
} 
$page_ up=$page id-1; 
$page_down=$page id+1; 
if ($page id==1){ 
echo "<a href=?".$add."page id=".$page_ down."> 下 一 页 </a>g&nbsp;&nbsp; 
第 ".$page_iqd." 页 , 共 ".$page_num." 页 "; 
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} 
else if ($page id>=$page num-1){ 
echo "<a href=?".$add."page id=".$page up."> 上 一 页 </a>&nbsp;&nbsp; 
第 ".$page_id." 页 , 共 ".$page_num." 页 "; 


else{ 
echo "<a href=?".$add."page id=".$page up."> > 页 


</a>gnbsp; gnbsp; <a href=?".$add."page id=".$page down."> 下 一 页 </a>&nbsp;&nbsp; 第 
".$page_id." 页 , 共 ".$page_num." 页 "; 
} 
$page_ jump=$num per page* ($page id-1); 
$query=$query." limit $page jump,$num per page"; 
) 
}//end myfunction 
Se 


21.3.2 ”论坛 主页 面 


论坛 主页 面 的 相关 文件 如 下 。 
文件 head.php 位 于 配套 素材 包 的 ch2l\inc\ 下 ， 为 论坛 的 头 文件 ， 代 码 如 下 。 


<?php 

@session start(); 

?> 

<style type="text/css"> 
eI 


Q@font-face { 
font-family: 'Hanyihei'; 
src: Url ("inc/hanyihei .ttf") format ("truetype"); 
font-style: normal; } 
Q@font-face { 
font-family: 'Minijanxixingkai'; 
src: url("inc/minijanxixingkai.ttf") format ("truetype"); 
font-style: normal; } 
.STYLE1 { 
font-family: 'Hanyihei'; 
font-size: 36px; 
color:#024f6c; 
。STYLE2 { 
font-family: 'Hanyihei'; 
--> 
</style> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="1"> 
EP 
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<td height="60" bgcolor="f0b604"><span class="STYLE1">&nbsp;&nbsp; 迅 捷 BBS 
系统 </span></td> 
E> 
<tr> 
<td height="2"></td> 
</tr> 
</table> 


文件 foot.php 位 于 配套 素材 包 的 ch21\inc\ 下 ， 为 论坛 的 版 权 文件 ， 具 体 代码 如 下 。 


<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
Er 
<td height="10"></td> 
</tr> 
< 
<td height="10" bgcolor="#5F8AC5"></td> 
</tr> 
<tr> 
<td height="40" align="center" valign="middle" bgcolor="#f0b604"> 建 议 使 用 
浏览 器 IE 6.0 以 上 分 辨 率 1024*768 以 上 <br /> 
版 权 所 有 : <a href="http://www.quickbbs.net" target=" blank"> 迅 捷 BBS</a> 
</td> 
</tr> 
</table> 


文件 total_info.php 位 于 配套 素材 包 的 ch21l\inc\ 下 ， 为 论坛 的 总 信息 文件 。 具 体 代码 如 下 。 


<?php 
//@session start(); 
4/ 用 户 登 录 并 注册 SESSION 
if(isset($ POST['tijiao'])){ 
$tijiao=$_POST['tijiao']; 
} 
if (@$tijiao==" 提 交 ") { 
$user name=@$_POST['user name']; 
$user pw=@$_ POST['user pw']; 
$check query="select * from user info where user name='".S$user name."'"; 
$check rst=$aa->excu($check query); 
$user=mysqli fetch array($check rst); 
if ($user pw==$user['user pw’']){ 
$_SESSION['user name']=$user['user name']; 
Stoday=date("Y-m-d H:i:s"); 
$query="update user info set time2='".$today."’' 
where user name='".$ SESSION['user name']."'"; 
$aa->excu ($query); 
} 
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if (@$tijiao==" 安 全 退出 ") { 

$_SESSION['user name']=""; 

} 

?> 

<table width="98%" border="0" align="center" cellpadding="0" cellspacing="1"> 
<tr><form id="forml" name="forml" method="post" action="#"> 


<td width="80%" height="25" align="left" valign="middle" 
bgcolor="5F8AC5">&nbsp; 
<?php 
if (@$_ SESSION['user name'] !=""){ 


echo "<font color=ffffff> 欢 迎 您 :".$_SESSION['user name']."</font>"; 
echo "gnbsp;&nbsp; gnbsp; &nbsp; gnbsp; gnbsp; gnbsp; &nbsp; gnbsp; 
<input type='submit' name='tijiao' value=' 安 全 退出 '>"; 
}else{ 
i 
用 户 名 : 
<input type="text" name="user name" size="8" /> 
密码 :<input type="text" name="user pw" size="8" /> 
<input type="submi name="tijiao" value=" 提 交 "” /> 
&nbsp;&nbsp;<a href="register.php"><font color="#FFFFFF"> 我 要 注册 
</font></a> 
<?php 





二 二 


Se 
</td> 
</form> 
<td width="20%" align="right" valign="middle" bgcolor="5F8RC5"> 
<?php 
$today=date ("Y-m-d H:i:s"); 
echo $today; 
Es 
</td> 
</tr> 
E> 
<td height="25" colspan="2" align="right" valign="middle"> 帖 子 总 数 : <?php 
echo $bb->note total num();?>&nbsp;&nbsp; 会 员 总 数 : <?php 
echo $bb->user total num();?>&nbsp;&nbsp; 欢 迎新 会 员 : 
<?php echo $bb->last username();?>&gnbsp;&nbsp;</td> 
< 
“Er 
<td height="13" colspan="2" align="right" valign="middle">&nbsp;</td> 
二 7 
</table> 


文件 index.php 位 于 配套 素材 包 的 ch21\ 下 ， 是 用 户 访问 的 主页 。 具 体 代 码 如 下 。 
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<htm1> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 





<title>=== 迅 捷 BBS 系统 ===</title> 

<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 

<body> 

<?php 


@session start(); 

include "inc/mysql.inc"; 
include "inc/myfunction.inc"; 
include "inc/head.php"; 
$aa=new mysqlconn; 

$bb=new myfunction; 
$aa->link(""); 

include "inc/total info.php"; 
2 


<table class='indextemp' width="98%" border="0" align="center" cellpadding="0" 


cellspacing="1" bgcolor="#FFFFFF"> 
<tr> 


<td width="50%" height="25" align="center" valign="middle" 


bgcolor="5F8AC5"> 
<span class="STYLE2"> 讨 论 区 </span></td> 
<td width="10%" align="center" valign="middle" 
class="STYLE2"> 
主 题 </span></td> 
<td width="10%" align="center" valign="middle" 
class="STYLE2"> 
帖 子 </span></td> 
<td width="20%" align="center" valign="middle" 
class="STYLE2"> 
最 新 帖子 </span></td> 
<td width="10%" align="center" valign="middle" 
class="STYLE2"> 
版 主 </span></td> 
</Er 





bgcolor="5F8AC5"><span 


bgcolor="5F8AC5"><span 


bgcolor="5F8AC5"><span 


bgcolor="5F8AC5"><span 


$query="select * from father module info order by id"; 


$result=$aa->excu ($query); 
while($father module=mysqli fetch array ($result)){ 
?> 


<table width="100%" border="0" cellspacing="0" cellpadding="0"> 


<tEr> 
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<td height="25" colspan="6" bgcolor="98B2CC">&nbsp;é&nbsp; gnbsp; gEnbsp; 
<img src="pic_ sys/1i-1.gif" width="16" height="15">&nbsp;é&nbsp; &nbsp;&nbsp; 
<?php echo $father module['module name']?></td> 


< NEL 
<?php 
$query2="select * from son module info where father module id='". 
$father module['id']."'order by id"; 


$result2=$aa->excu ($query2); 
while($son module=mysqli fetch array($result2)){ 
?> 
<tr> 
<td width="5%" height="40" align="center" valign="middle"><img 
src="pic sys/1i-2.gif" 
width="32" height="32"></td> 
<td width="45%" align="left" valign="middle"> 
<?php 
echo "<b><a href=module list.php?module id=".$son module['id']."> 
<font color=0000ff>".$son module["module name"]."</font></a></b><br />"; 
echo $son module["module cont"]; 
人 </td> 
<td width="10%" align="center" valign="middle"><?php 
echo $bb->son module idtonote num($son module["id"]);?></td> 
<td width="10%" align="center" valign="middle"><?php 
echo $bb->son module idtonote num2 ($son module["id"]);?></td> 
<td width="20%" align="left" valign="middle"><?php 
echo $bb->son module idtolast note($son module["id"]);?></td> 
<td width="10%" align="center" valign="middle"><?php 


echo $bb->son module idtouser name ($son module["id"]);?></td> 
</tr> 
<?php }?> 
</table> 

<?php } ?> 
</td> 

</tr> 
</table> 
<?php 
include "inc/foot.php"; 
?> 
</body> 
</html> 


主页 面 运行 后 效果 如 图 21-2 所 示 。 
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图 21-2 论坛 主页 面 


21.3.3 ”新 用 户 注册 页 面 


文件 register.php 位 于 配套 素材 包 的 ch21\ 下 ， 是 新 用 户 注 册页 面 。 具 体 代码 如 下 。 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>=== 迅 捷 BBS 系统 ===</title> 

<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 

<body> 

<?php 

include "inc/mysql.inc"; 

include "inc/myfunction.inc"7 

include "inc/head.php"; 

$aa=new mysqlconn; 

$bb=new myfunction; 

$aa->link(""); 

include "inc/total info.php"; 


2 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
EE 
<td width="73%" height="30"><a href="./"> 迅 捷 B B S 系统 </a>>> 新 用 户 注册 </td> 
<td width="27%" align="right" valign="middle"><a 
href="new note.php"></a></td> 
HEr> 
</table> 


<table width="98%" border="0" align="center" cellpadding="0" cellspacing="1" 
bgcolor="#FFFFFF"> 
tr 
<td height="25" align="center" valign="middle" bgcolor="5F8AC5"> 发 布 新 帖 
</td> 
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</tr> 
<tr> 
<td height="25" align="center" valign="middle"> 
<?php 
/ /接收 提交 表单 内 容 检验 数据 库 中 是 否 已 经 存在 此 用 户 名 ， 不 存在 写 入 数据 库 
$tijiao=@$ POST['tijiao']; 
if ($tijiao==" 提 交 "){ 
$user name=@$_ POST['user name']; 
$query="select * from user info where user name='$user name'™"; 
$rst=$aa->excu ($query); 
if (mysqli num rows($rst)!=0){ 
echo 注册 的 用 户 名 已 经 存在 ， 请 选择 其 他 的 用 户 名 重新 注册 ! = 
}elsef{ 
$user pwl=$_POST['user pwl']; 
$user pw2=$_POST['user pw2']; 
if ($user pwl!=$user pw2){ 
两 次 输入 的 密码 不 匹配 ， 请 重新 输入 ! ==="; 














}elsef{ 
$today=date("Y-m-d H:i:s"); 
$query="insert into user info 
(user name,user pw,timel) values('$user name','$user pwl','$today')"; 
if ($aa->excu($query)){ 
echo "=== 恭 喜 您 ， 注 册 成 功 ! 请 <a href=../> 





; 
$register tag=1; 


} 

// 显 示 注册 表单 

if (@$register tag!=1){ 

?> 

<form name="forml" method="post" action="#"> 

<table width="500" border="0" cellpadding="0" cellspacing="2"> 


<tr> 
<td width="121" height="26" align="right" valign="middle" 
bgcolor="#CCCCCC"> 
用 户 名 :</td> 
<td width="372" height="26" align="left" valign="middle" 


bgcolor="#CCCCCC"><input 
type="text" name="user name"></td> 
</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 密 
码 :</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 
<input type="text" name="user pwl"></td> 
<HEES 
< 

















图 21-3 新 用 户 注册 页 面 
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注册 完成 后 ， 即 可 在 主页 面 输入 用 户 名 和 密码 ， 单 击 【 提 交 】 按 钮 ， 登 录 论 坛 系统 。 登 录 后 
效果 如 图 21-4 所 示 。 单 击 【 安 全 退出 】 按 钮 ， 即 可 退出 登录 操作 。 
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图 21-4 用户 成 功 登录 页 面 
21.3.4 ”论坛 帖子 的 相关 页 面 


下 面 介绍 论坛 帖子 的 相关 页 面 。 

文件 new_note.php 位 于 配套 素材 包 的 ch21\ 下 ， 是 用 于 发 布 新 帖 的 页 面 。 具 体 代 码 如 下 。 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>=== 迅 捷 BBS 系统 ===</title> 


<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 


<body> 

<?php 

//@session start(); 

include "inc/mysql .inc"7 

include "inc/myfunction.inc"; 

include "inc/head.php"; 

$aa=new mysqlconn; 

$bb=new myfunction; 

$aa->link(""); 

include "inc/total info.php"; 

2 

<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 

<E¥S 

<td width="73%" height="30"><a href="./"> 迅 捷 B B S 系统 </a>>> 发 新 帖子 </td> 
<td width="27%" align="right" valign="middle"><a href="new note.php"> 
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<img src="pic sys/post.gif" width="82" height="20"></a></td> 
a 
</table> 
<table width="98%" border= 
bgcolor="#FFFFFF"> 
<tP> 
<td height="25" align="center" valign="middle" bgcolor="5F8AC5"> 发 布 新 帖 
</td> 
</tr> 
<tr> 
<td height="25" align="center" valign="middle"> 





" align="center" cellpadding="0" cellspacing="1" 


<?php 

if (@$_ SESSION['user name'] 
echo "=== 请 先 登 录 ! =="; 
}elsel 
// 接 收 提交 表单 内 容 写 入 数据 库 
$tijiao=@$_ POST['tijiao']; 
if ($tijiao==" 提 交 "){ 

$module id=@$_POST['module id']; 

$title=@$ POST['title']; 

$cont=@$_POST['cont']; 

$cont=$bb->str_ to ($cont); 

$today=date("Y-m-d H:i:s"); 

if ($module id!="" and $title!="" and $cont!=""){ 

$query="insert into note info 





5 








(module id,title,cont,time,user name) 
values('$module id','$title','$cont','$today','".$_SESSION['user name']."')"; 
if ($aa->excu ($query)){ 
echo "=== 新 帖 发 布 成 功 ， 请 继续 ! 
} 
}else{ 


echo "=== 请 选择 子 模拟 ， 而 且 标题 和 内 容 均 不 能 为 空 ! ==="; 





} 


2 





<form name="forml" method="post" action="new note.php"> 
<table width="500" border="0" cellpadding="0" cellspacing="2"> 





<tr> 
<td width="122" height="26" align="right" valign="middle" 
bgcolor="#CCCCCC"> 隶 属 版 块 :</d> 
<td width="372" height="26" align="left" valign="middle" 
bgcolor="#CCCCCC"> 
<?php 


$bb->son module list(""); 
?> 
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</td> 
<HEE> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 标 
题 :</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 
<input type="text" name="title"></td> 
</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 内 
容 :</td> 
<td height="26" alig; 
<textarea name="cont" cols= 
</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 发 帖 






"left" valign="middle" bgcolor="#CCCCCC"> 
50" rows="8"></textarea></td> 





人 :</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC">gnbsp; 
<?php echo $_SESSION['user name'];?></td> 
</tr> 
=Er> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 时 
间 :</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 系 统 将 
自动 记录 ! </td> 
</tr> 
<tr> 
<td height="26" colspan="2" align="center" valign="middle" 
bgcolor="#CCCCCC"> 
<input type="submit" name="tijiao" value=" 提 交 ">gnbsp; gnbsp;&nbsp; &nbsp; 
<input type="reset" name="Submit2" value=" 重 置 "></td> 
</tr> 
</table> 
</form> 
<?php 
} 
?> 
</td> 
</tr> 
“Er> 
<td height="1" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<?php 
include "inc/foot.php"; 
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发 布 新 帖 的 页 面 效 果 如 图 21-5 所 示 。 
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21-5 发布 新 帖 页 面 
文件 note_show.php 位 于 配套 素材 包 的 ch21\ 下， 是 显示 帖子 和 相关 回复 的 页 面 。 具 体 代码 如 下 。 





七 -TVF ontenl xt /htm charset=gh 
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<?php 

echo "<a href=module list.php?module id=" .Smodule id.">"; 

echo $bb->son module idtofather_name (Smodule id); 

echo "</a>>>"; 

echo $bb->son module idtomodule name (Smodule id); 

// 删 除 回复 

$del id=$_GET[del id]; 

TE (Sade i = 
if ($bb->son module idtouser name($module id)==$_ SESSION[user name]){ 
$del query="delete from note info where id='$del id'"; 
$aa->excu($del query); 
echo "<br />=== 删 除 回 复 成 功 ! ==="; 





! 
// 添 加 回复 
$tijiao=$_ POST[tijiao]; 
if ($tijiao==" 提 交 "){ 
$title=$_POST[title]; 
$cont=$_POST[cont]; 
$cont=$bb->str_ to ($cont); 
$today=date("Y-m-d H:i:s"); 
if ($_SESSION[user name]==""){ 
$user_name=" 游 
}else{ 
$user name=$_SESSION [user name]; 





} 
$query="insert into note info(up id,title,cont,time,user name) 
values('S$note id','$title','$cont','$today', '$user name')"; 
$aa->excu ($query); 
F 
?></td> 
<td width="16%" align="right" valign="middle"><a href="#huifu"> 
img src="pic sys/reply.gif" width="82" height="20"></a></td> 
<td width="11%" align="right" valign="middle"><a href="new note.php"> 
pic_sys/post.gif" width="82" height="20"></a></td> 





<img src= 
</tr> 
</table> 
<?php 
$query="select * from note info where up_ id='$note id' order by time"; 
$add="module id=".$module id."&note_ id=".S$note id."g"; 
re 
<table width="98%" border=" 
<tr> 
<td height="30" align="left" valign="middle"><?php $bb->page ($query, 
$page_id, $add,20)?> 





align="center" cellpadding="0" cellspacing="0"> 
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</td> 
</tr> 
</table> 
<?php 
$query2="select * from note info where id='Snote id'"; 
$result2=$aa->excu ($query2); 
$note2=mysqli fetch array ($result2); 
> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="1" 
bgcolor="#FFFFFF"> 
<tr> 
<td width="71%" height="25" align="]left" valign="middle" bgcolor="5F8AC5"> 
标题 : 
<?php 
echo $note2[title] ?></td> 
<td width="29%" align="center" valign="middle" bgcolor="5F8AC5"> 发 帖 时 间 : 
<?php echo $note2[time]?></td> 
</tr> 
<tr> 
<td height="1" colspan="2" bgcolor="#CCCCCC"></td> 
</tr> 
</table> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="16%" height="15" align="center" valign="top"><img 
src="pic_sys/head2.jpg" 
width="85" height="90"><br /><?php echo $note2 [user name]?></td> 


<td align="left" valign="middle"><?php echo $note2[cont]?></td> 
</tr> 


< 
<td height="8" colspan="2" align="center" valign="top" bgcolor="#5F8AC5"> 
</td> 
</tr> 
</table> 
<?php 
$rst=$aa->excu ($query); 
if (mysqli num rows ($rst)!=0){ 
> 
<table width="98%" border= 
<?php 





align="center" cellpadding="0" cellspacing: 





while ($note=mysqli fetch array($rst)){ 
> 


<tr> 


<td width="16%" height="120" rowspan="3" align="center" valign="top"> 
<?php 


EZ 
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if (Snote[user_name] 游客 ") { 
es 
<img src="pic_ sys/headl.png" width="100" height="100"> 
<br /> 
游客 
<?php 
}elsef 
二 
<img src="pic_sys/head2.jpg" width="85" height="90"><br /> 
<?php 
echo $note[user name]; 
} 
?> 
</td> 
<td width="54%" height="26" align="left" valign="middle"><?php echo 
$note[title]?></td> 
<td width="18%" height="26" align="center" valign="middle"><?php echo 
$note[time] ?></td> 
<td width="12%" height="26" align="center" valign="middle"> 
<?php 
if ($bb->son module idtouser name($module id)==$_SESSION [user name] 11 
$_SESSION 
[manage tag]==1){ 
echo "<a href=? 
module id=".$module id."gnote id=".$note id."g&page id=".$page id."g&del id=" 
.$note[id]."> 
圳 除 回复 </a>"; 
} 
?> </td> 
</tr> 
<tr> 
<td height="1" colspan="3" align="]left" valign="top" bgcolor="#CCCCCC"> 
</td> 
</tr> 
<tr> 
<td height="70" colspan= 
$note[cont] ?></td> 
se 
<tr> 





3" align="left" valign="top"><?php echo 


<td height="2" colspan="4" align="center" valign="top" bgcolor="#CCCCCC"> 
<NEd> 
</tr> 
<2php }2> 
</table> 
<?php 
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上 
2> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="30" align="right" valign="bottom"><?php 
$query="select * from note info where up id='$note id' order by time desc"; 
$bb->page ($query, $page_id, $add,20); 
?></td> 
</tr> 
</table> 
<form name="forml" method="post" action="#"> 
<table width="500" border="0" align="center" cellpadding="0" cellspacing="2"> 
< 
<td height="26" colspan="2" align="center" valign="middle" 
bgcolor="#CCCCCC"> 
<a name="huifu"> 回 复 此 帖 </a></td> 
</tr> 
<tr> 
<td width="122" height="26" align="right" valign="middle" bgcolor= 
"#CCCCCC"> 标 题 :</td> 
<td width="372" height="26" align="left" valign="middle" bgcolor= 
"#CCCCCC"> 


<?php 
$reply_title=" 回 复 :".$bb->note idtotitle ($note id); 
echo S$reply title; 
> 
<input type="hidden" name="title" value="<?php echo S$reply title?>"> 
</td> 
</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 内 容 :</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC"> 
<textarea name="cont" cols="50" rows="8"></textarea></td> 
</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 发 帖 
</td> 
<td height="26" align="left" valign="middle" bgcolor="#CCCCCC">gnbsp; 


<?php 
if ($_SESSION[user name]==""){ 
echo "游客 "; 
}elsef{ 


echo $_ SESSION[user name]; 








21-6 回复 帖子 页 面 


文件 module listphp 位 于 配套 素材 包 的 ch21\ 下 ， 是 显示 子 模块 下 帖子 列表 的 页 面 。 具 体 代码 
如 下 。 
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<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 

<body> 

<?php 

@session start(); 

include "inc/mysql.inc"; 

include "inc/myfunction.inc"; 

include "inc/head.php"; 

$aa=new mysqlconn; 

$bb=new myfunction; 

$aa->link(""); 

include "inc/total info.php"; 

$module id=@$_ GET['module id']; 

$del id=@$ GET['del id']; 

if ($bb->son module idtouser name($module id)==@$_ SESSION['user name']){ 
$query="delete from note info where id='".$del id."'"; 
$aa->excu ($query); 

} 


$query="select * from note info where module id='".$module id."' order by time 


desc"; 
$add="module id=".$module id."g"; 
2 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="73%" height="30"><a href="./"> 迅 捷 BBS 系统 </a>>> 
<?php 


echo "<a href=module list.php?module id=".$module id.">"; 
echo $bb->son module idtofather name ($module id); 
echo "</a>>>"; 
echo $bb->son module idtomodule name ($module id); 
?></td> 
<td width="27%" align="right" valign="middle"><a href="new note.php"> 
<img src="pic_ sys/post.gif" width="82" height="20"></a></td> 
</tr> 
</table> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="30" align="left" valign="middle"><?php $bb->page ($query, 
@$page_id,$add,20) ?></td> 
</tr> 
</table> 
<table width="98%" border=" 
bgcolor="#FFFFFF"> 
<tr> 
<td width="3%" height="25" align="center" valign="middle" bgcolor="5F8RC5" 





align="center" cellpadding="0" cellspacing="1" 
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>gnbsp;</td> 
<td width="5%" align="center" valign="middle" bgcolor="5F8AC5"> 人 气 </td> 
<td width="50%" align="center" valign="middle" bgcolor="5F8AC5"> 标 题 
</tad> 
<td width="9%" align="center" valign="middle" bgcolor="5F8AC5"> 发 起 人 </td> 
<td width="5%" align="center" valign="middle" bgcolor="5F8AC5"> 帖 子 数 </td> 
<td width="16%" align="center" valign="middle" bgcolor="5F8AC5"> 最 后 发 表 时 
间 </td> 
<td width="12%" align="center" valign="middle" bgcolor="5F8AC5"> 最 后 发 表 人 
</td> 
/EE 
<?php 
$result=$aa->excu ($query); 
while($note=mysqli fetch array ($result)){ 
?> 
<tr> 
<td height="25" align="center" valign="middle"><img src="pic sys/1i-3.gif" 
width="14" height="11"></td> 
<td height="25" align="center" valign="middle"><?php echo $bb->note_ 
idtotimes ($note['id']);?></td> 
<td height="25" align="left" valign="middle"><?php 
echo "<a href=note_ show.php?module id=".$module id."gnote id=".$note['id']. 
">".$note['title']."</a>"; 
if ($bb->son module idtouser name($module id)==$_SESSION['user name'] 
11 $_SESSION['manage tag']==1){ 
echo "gnbsp;&nbsp; 
<a 
href=module list.php?module id=".$module id."g&page id=".$page id."g&del id=".$n 
ote['id'] ."> 
删除 此 帖 </a>"; 
lL 
?></td> 
<td height="25" align="center" valign="middle"><?php echo Snote['user_ 
name'];?></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $bb->note idtonote num($note['id']);?></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $bb->note idtolast time ($note['id']);?></td> 
<td height="25" align="center" valign="middle"> 
<?php echo $bb->note idtolast user name ($note['id']);?></td> 
</EE> 
<tr> 
<td height="1" colspan="7" bgcolor="#CCCCCC"></td> 
= /Er 
<?php 
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4 
> 
</table> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td height="30" align="right" valign="bottom"> 
<?php 
$query="select * from note_info where module id='".$module id."' order by time 
desc"; 
$bb->page ($query,@$page id, $add, 20) 
?></td> 
</tr> 
</table> 
<?php 
include "inc/foot.php"; 
</body> 
</html> 


显示 帖子 的 页 面 效 果 如 图 21-7 所 示 。 
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图 21-7 显示 帖子 列表 页 面 


21.3.5 ”后 台 管 理 系统 的 相关 页 面 


下 面 介 绍 后 台 管 理 系统 的 相关 页 面 。 
文件 login.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 管理 用 户 的 登录 页 面 。 具 体 代码 如 下 。 


<?php 
include "../inc/mysql.inc"; 
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include "../inc/myfunction.inc"; 

$aa=new mysqlconn; 

$bb=new myfunction; 

$aa->link(""); 
$_SESSION[ 'manage name']=""; 

$_SESSION['manage tag']=" 

?> 

<head> 

<style> 

ls 

td { font-size: 10Pt } 

--> 

</style> 

<title>: : :管理 员 登 录 == 迅 捷 BBS 系统 :: :</title> 

</head> 

<body onLoad="tijiao.username.value='';tijiao.username.focus();"> 





<p align="center"> </p> 


<br /> 
</font></p> 

<div align="center"> 
<center> 


<form method=POST name="tijiao" action="auth.php"> 
<table border="1l" cellpadding="0" cellspacing="0" bordercolor="#111111" 
width="240" 


height="126" bordercolorlight="#FFFFFF" bordercolordark="#FFFFFF" 
style="border-collapse: collapse"> 
<tr> 


<td width="238" colspan="2" height="25" bgcolor="#A8A3AD"> 
<p align="center"><b><font color="#FFFFFF"> 迅捷 BBS 后 台 管 理 系 统 
</font></b></td> 
</tr> 






"64" height="26" bgcolor="#E3E1E6"> 
<p align="center"> 账 Enbsp; 号 : </td> 
<td height="26" bgcolor="#E3El1E6" width="173"> 
<input type="text" name="username" size="20" style="color: #A8A3AD; 
border-style: solid; 
border-width: 1; padding-left: 4; padding-right: 4; padding-top: 1; 
padding-bottom: 1"></td> 
</Er> 
<tr> 
<td width="64" height="26" bgcolor="#E3E1E6"> 
<p align="center"> 口 snbsp; 令 : </td> 
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<td height="26" bgcolor="#E3E1E6"” width="173"> 
<input type="password" name="password" size="20" style="color: #A8A3AD; 
border-style: solid; 
border-width: 1; padding-left: 4; padding-right: 4; padding-top: 1; 
padding-bottom: 1"></td> 
</Er> 
< 
<td width="238" height="29" bgcolor="#E3E1E6" colspan="2"> 
<P align="center"><input type="submit" value=" 登 录 "” name="login"> 
&nbsp; gnbsp; gnbsp; gnbsp; 
<input type="reset" value=" 取 消 " name="cancel"></td> 
</tr> 
<tr> 
<td width="238" colspan="2" height="20" bgcolor="#A8A3AD"> </td> 
</tr> 
</table> 
</form> 
</center> 
</div> 
</body> 


管理 用 户 的 登录 页 面 效 果 如 图 21-8 所 示 。 


[¢ 疾 碟 htpy/loc. @ PD BOX|@localhost 


文件 (月 ”编辑 (E) ”前 看 (V) ”收藏 夫 (A) 工具 (T) ”帮助 (H) 


迅捷 BBS 后 台 管理 系统 


账 号 | 
口令 : 






































图 21-8 管理 用 户 的 登录 页 面 


文件 session.inc 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 检验 Session 是 否 存在 的 页 面 。 具 体 代 
码 如 下 。 
<?php 
Q@session start(); 
//if ($_SESSION['manage name']=="" and $_ SESSION['manage tag']!=1){ 
Va header ("location:./login.php"); 
dt 


?> 
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文件 index_top.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 后 人 台 管 理 主页 面 的 上 部 页 面 。 具 体 
代码 如 下 。 


<HTML> 
<HEAD><TITLE> 顶 部 管理 导航 菜单 </TITLE> 
<META http-equiv=Content-Type content="text/html; charset=gb2312"> 
<STYLE type=text/css>A:link { 
COLOR: #ffffff; TEXT-DECORATION: none 
} 
A:hover { 
COLOR: #ffffff 
} 
A:visited { 
COLOR: #f0f0f0; TEXT-DECORATION: none 
} 
.spa { 
FONT-SIZE: 9pt; FILTER: Glow (Color=#0F42A6, Strength=2) 
dropshadow (Color=#0F42A6, OffX=2, OffY=1,); COLOR: #8aade9; FONT-FAMILY: ' 宋 体 ' 
} 
IMG { 
FILTER: Alpha (opacity:100); chroma: #FFFFFF) 
| 
</STYLE> 
<SCRIPT language=JavaScript type=text/JavaScript> 
function preloadImg (src) { 
Var img=new Image(); 
img.src=src 
} 
preloadIimg ('image/admin top_open.gif'); 


var displayBar=true; 
function SwitchBar (obj) { 

if (displayBar) { 
Parent .frame.cols='0,*'; 
displayBar=false; 
obj.src='image/admin top open.gif'; 
obj .title=' 打 开 左边 管理 导航 菜单 '; 
else { 
Parent .frame.cols="'200,*"'; 


一 


displayBar=true; 
obj .src='image/admin top close.gif'; 


obj .title=' 关 闭 左 边 管理 导航 菜单 '; 


} 
</SCRIPT> 
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<META content="MSHTML 6.00.2900.2963" name=GENERATOR></HEAD> 
<BODY leftMargin=0 background=image/admin top bg.gif 
topMargin=0> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR vAlign=center> 
<TD width=60><IMG title= 关 闭 左边 管理 导航 菜单 style="CURSOR: hand" 
onclick=switchBar (this) 
src="image/admin top close.gif"></TD> 
<TD width=92><A href="login.php" target=" parent" ><IMG 
src="image/top an 1.gif" border=0></A></TD> 
<TD width=92><A href="#"></A></TD> 
<TD width=104><A href="#"></A></TD> 
<TD width=92><A href="#"></A></TD> 
<TD width=92><A href="#"></A></TD> 
<TD class=spa align=right>ET PHP SOUND CODE DEVELOP &nbsp; 
</TD> 
</TR> 
</TBODY> 
</TABLE> 
</BODY> 
</HTML> 





文件 index_left.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 后 台 管 理 主页 面 的 左 侧 页 面 。 具 体 
代码 如 下 。 
<?php 
include "session.inc"; 
?> 
<HTML> 
<HEAD><TITLE> 管 理 导 航 菜单 </TITLE> 
<META http-equiv=Content-Type content="text/html; charset=gb2312"> 
<SCRIPT src="menu.js"></SCRIPT> 
<LINK href= 
</HEAD> 
<BODY leftMargin=0 topMargin=0 marginwidth="0" marginheight="0"> 
<TABLE cellSpacing=0 cellPadding=0 width=180 align=center border=0> 
<TBODY> 
<TR> 





left.css" type=text/css rel=stylesheet> 


<TD vAlign=top height=44><IMG 
src="image/title.gif"></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=180 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitle0 
onmouseover="this.className='menu title2';" 
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onmouseout="this.className='menu title';" 
background=image/title bg quit.gif 
height=26>&nbsp; &nbsp;<A href="Admin Main.php" target=" top"><B><SPAN 
class=glow> 
管理 首页 </SPAN></B></A><SPAN class=glow> | 
</SPAN><A href="login.php" target=" top"><B><SPAN class=glow> 退 出 
</SPAN></B></A> </TD></TR> 
> 
<TD id=submenu0 background=image/title bg admin.gif height=97> 
<DIV style="WIDTH: 180px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=16> 您 的 用 户 名 : <?php echo @$_SESSION['manage _name'];?> 
</TD></TR> 
<TR> 
<TD height=16> 您 的 身份 : <?php echo @$_SESSION['manage _name'];?> 
</TD></TR> 
<TR> 
<TD height=16>IP: <?php echo $_SERVER["REMOTE ADDR"] ;?></TD> 
</TR> 
<TR> 
<TD height=16>&nbsp;</TD> 
</TR> 
</TBODY></TABLE></DIV> 
<DIV style="WIDTH: 167px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD 
height=20></TD></TR></TBODY></TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=167 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitlel 
onmouseover="this.className='menu title2'" style="CURSOR: hand" 
onclick="new Element.toggle('submenul')" 
onmouseout="this.className='menu title'" 
background=image/Admin left 1.gif height=28 ;><SPAN class=glow> 论 坛 版 块 管 
理 </SPAN></TD> 
</TR> 
二 
<TD id=submenul style="DISPLAY: none" align=right> 
<DIV class=sec menu style="WIDTH: 165px"> 
<TABLE cellSpacing=0 cellPadding=0 width=132 align=center> 
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<TBODY> 
<TR> 
<TD height=20><A href="father module add.php"” target=main> 父 版 块 添加 
</R></TD> 
</TR> 
<TR> 
<TD height=20><A href="father module 1ist.php"” target=main> 父 版 块 管理 
</R></TD> 
</TR> 
<TR> 
<TD height=20><A href="son module add.php" target=main> 子 版 块 添加 
</R></TD> 
</TR> 
<TR> 
<TD height=20><A href="son module list.php"” target=main> 子 版 块 管理 
</A></TD> 
</TR> 
</TABLE> 
</DIV> 
<DIV style="WIDTH: 158px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD 
height=4></TD></TR></TBODY></TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=167 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitle2 
onmouseover="this.className='menu title2'" style="CURSOR: hand" 
onclick="new Element.toggle('submenu2')" 
onmouseout="this.className="'menu title'" 
background=image/Admin left 11.gif height=28 ;><SPAN class=glow> 论 坛 用 户 管 
理 </SPAN></TD> 
</TR> 
<TR> 
<TD id=submenu2 style="DISPLAY: none" align=right> 
<DIV class=sec menu style="WIDTH: 165px"> 
<TABLE cellSpacing=0 cellPadding=0 width=132 align=center> 
<TBODY> 
<TR> 
<TD height=20><A href="user list.php” target=main> 所 有 用 户 </A></TD> 
</TR> 
<TR> 
<TD height=20><A href="user js.php"” target=main> 用 户 检 索 </A></TD> 
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</TR> 
</TBODY></TABLE> 
</DIV> 
<DIV style="WIDTH: 158px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD 
height=4></TD></TR></TBODY></TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=167 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitle3 
onmouseover="this.className='menu title2'" style="CURSOR: hand" 
onclick="new Element .toggle('submenu3')" 
onmouseout="this.className='menu title'" 
background=image/Admin left 3.gif height=28 ;><SPAN class=glow> 安 全 管理 
</SPAN></TD> 
</TR> 
<TR> 
<TD id=submenu3 style="DISPLAY: none" align=right> 
<DIV class=sec menu style="WIDTH: 165Px"> 
<TABLE cellSpacing=0 cellPadding=0 width=132 align=center> 
<TBODY> 
<TR> 
<TD height=20><A href="user pw_change.php" target=main> 密 码 更 改 





</A></TD> 
</TR> 
<TR> 
<TD height=20><A href="../" target=_blank> 帖 子 管理 </A></TD> 
</TR> 
</TBODY></TABLE> 
</DIV> 
<DIV style="WIDTH: 158px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD 
height=4></TD></TR></TBODY></TABLE></DIV></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width=167 align=center> 
<TBODY> 
<TR> 
<TD class=menu title id=menuTitle208 
onmouseover="this.className='menu title2';" 
onmouseout="this.className='menu title';" 
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background=image/Admin left 04.gif 
height=28><SPAN> 系 统 信 息 </SPAN> </TD></TR> 
<TR> 
<TD align=right> 
<DIV class=sec menu style="WIDTH: 165px"> 
<TABLE cellSpacing=0 cellPadding=0 width=130 align=center> 
<TBODY> 
<TR> 
<TD height=20><br /> 版 本 号 :verson 1.0<br /> 版 权 所 有 : g&nbsp;<A href= 
"http://www.quickbbs .net/" target= blank> 迅 捷 BBS</R> 
<br /> 设计 制作 : &nbsp;<A href="http://www.etpt.net/" target= blank> 迅 捷 


BBS</A> 
<br /> 技术 支持 : &nbsp;<A href="http://bbs.etpt.net/" target= blank> 迅 捷 
BBS</A> 
<br /><br /></TD></TR></TBODY></TABLE></DIV></TD></TR> 
</TBODY></TABLE> 
</BODY> 
</HTML> 


文件 index_right.php 位 于 配套 素材 包 的 ch21\manage\ 下 ,是 后 台 管 理 主页 面 的 右 侧 页 面 。 具体 
代码 如 下 。 
<?php 
include "fun head.php"; 
head ("管理 首页 ") ; 
?> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20 rowSpan=2>&gnbsp;</TD> 
<TD class=topbg align=middle width=100> 论 坛 版 块 管理 </TD> 
<TD width=300>&nbsp;</TD> 
<TD width=40 rowSpan=2>gnbsp;</TD> 
<TD class=topbg align=middle width=100> 论 坛 用 户 管理 </TD> 
<TD width=300>&nbsp;</TD> 
<TD width=21 rowSpan=2>&nbsp;</TD></TR> 
<TR class=topbg2> 
<TD colSpan=2 height=1></TD> 
<TD colSpan=2></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20>&nbsp;</TD> 
<TD width=400><br /> 
本 管理 版 块 共 分 四 个 子 模块 : 父 版 块 添加 、 父 版 块 管理 、 子 版 块 添加 、 子 版 块 管理 。 
其 中 父 版 块 添加 和 子 版 块 添加 可 以 实现 本 论坛 的 父 版 块 和 子 版 块 的 添加 ; 
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父 版 块 的 管理 和 子 版 块 的 管理 可 以 实现 本 论坛 父 版 块 和 子 版 块 的 删除 、 编 辑 等 功能 。<br /> 
</TD> 
<TD width=40>&nbsp;</TD> 
<TD 
width=400><br /> 
本 管理 模块 共 分 两 个 子 版 块 : 所 有 用 户 和 用 户 检索 。 
其 中 所 有 用 户 按 用 户 注册 的 先后 顺序 分 页 依次 列 出 。 
用 户 检索 是 由 管理 员 输 入 要 查询 的 论坛 注册 用 户 的 用 户 名 ， 系 统 通过 数据 库 查询 出 该 用 户 的 
相关 信息 ， 并 列 出 ， 而 且 管 理 员 也 可 以 在 查询 注册 用 户 后 直接 删除 该 用 户 。<br /> 
<br /></TD> 
<TD width=21>gnbsp;</TD></TR></TBODY></TABLE> 
<TABLE height=10 cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20 rowSpan=2>&gnbsp;</TD> 
<TD class=topbg align=middle width=100> 安 全 管理 </TD> 
<TD width=300>&nbsp;</TD> 
<TD width=40 rowSpan=2>&gnbsp;</TD> 
<TD class=topbg align=middle width=100> 系 统 信息 </TD> 
<TD width=300>&nbsp;</TD> 
<TD width=21 rowSpan=2>&nbsp;</TD></TR> 
<TR class=topbg2> 
<TD colSpan=2 height=1></TD> 
<TD colSpan=2></TD></TR></TBODY></TABLE> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=20>gnbsp;</TD> 
<TD 
width=400><br /> 
本 管理 模块 共 分 两 个 子 版 块 :密码 更 改 和 帖子 管理 。 
其 中 密码 更 改 提 供 了 管理 员 更 改 密码 的 功能 ， 但 必须 输入 原 密 码 和 两 次 新 密码 ; 
帖子 管理 是 直接 进入 论坛 的 主 界面 ， 但 与 普通 注册 用 户 所 不 同 的 是 ， 
在 论坛 的 每 个 发 帖 和 回复 后 面 都 多 了 一 个 删除 按钮 ， 可 以 通过 此 按钮 删除 相关 帖子 或 回复 。</TD> 
<TD width=40>&nbsp;</TD> 
<TD 
width=400 valign="top"><br /> 
本 版 块 提供 了 本 论坛 的 版 本 号 、 版 权 所 有 、 设 计 制 作 以 及 技术 支持 等 信息 。</TD> 
<TD width=21>gnbsp;</TD></TR></TBODY></TABLE> 
<TABLE height=70 cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
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<TR> 
<TD></TD></TR></TBODY></TABLE> 
<TABLE height=10 cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD></TD></TR></TBODY></TABLE> 
<br /> 
<?php 
include "bottom.php"; 
?> 


文件 bootom.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 后 台 管 理 主页 面 的 版 权 页 面 。 具 体 代 
码 如 下 。 


<TABLE class=border cellSpacing=1 cellPadding=2 width="100%" align=center 
border=0> 

<TBODY> 

<TR align=middle> 

<TD class=topbg height=25><SPAN class=Glow>Copyright 2012 &copy; 
<a href="http://www.quickbbs.net" target=" blank"><font color="#FFFFFF"> 迅 捷 
BBS</font></a> 
All Rights Reserved.</SPAN> </TD></TR> 

</TBODY> 
</TABLE> 


文件 index.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 后 台 管 理 的 主页 面 。 具 体 代码 如 下 。 
<?php 
include "session.inc"; 
2 
<HTML> 
<HEAD> 
<TITLE>=== 迅 捷 BBS 系统 -后 台 管理 ===</TITLE> 
<META http-equiv=Content-Type content="text/html; charset=gb2312"> 
</HEAD> 
<FRAMESET id=frame border=false frameSpacing=0 rows=* frameBorder=0 cols=200,* 
scrolling="yes"> 
<FRAME name=left marginWidth=0 marginHeight=0 src="index left.php" 
scrolling=yes> 
<FRAMESET border=false frameSpacing=0 rows=53,* frameBorder=0 Ccols=* 
scrolling="yes"> 
<FRAME name=top src="index top.php" scrolling=no> 
<FRAME name=main src="index right.php"> 
</FRAMESET> 
</FRAMESET> 


388。 
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文件 fun_head.php 位 于 配套 素材 包 的 ch21\manage\ 下 , 是 后 台 管 理 中 右 侧 页 面 中 的 头 文件 。 具 
体 代码 如 下 。 


<?php 
function head ($str){ 
> 
<LINK href="Admin Style.css" rel=stylesheet> 
<STYLE type=text/css> 
.STYLE4 { 
COLOR: #000000 
} 
</STYLE> 
<BODY leftMargin=0 topMargin=0 marginheight="0" marginwidth="0"> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD width=392 rowSpan=2><img height=126 
src="image/adminmain01 .gif" width=392></TD> 
<TD vAlign=top background=image/adminmain0line2.gif 
height=114> 
<TABLE cellSpacing=0 cellPadding=0 width="100%" border=0> 
<TBODY> 
<TR> 
<TD height=20></TD></TR> 
<TR> 
<TD><SPAN class=STYLE4> 频 道 管理 中 心 </SPAN></TD></TR> 
<TR> 
<TD height=8><IMG height=1 
src="image/adminmain0line.gif" width=283></TD></TR> 
<TR> 
<TD><IMG src="image/img u.gif™" 
align=absMiddle> 欢 迎 进入 管理 <FONT 
Color=#ff0000></FONT></TD></TR> 
<TR> 
<TD><IMG src="image/img u.gif" align=absMiddle> 
<?php 
echo "当前 位 置 : <b><font color=#ffffff>".$str."</font></b>"; 
?></TD> 
</TR> 
</TBODY></TABLE></TD></TR> 
<TR> 
<TD vAlign=bottom background=image/adminmain03 .gif 
height=9><IMG height=12 src="image/adminmain02 .gif" 
width=23></TD></TR></TBODY></TABLE> 
<?php 
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文件 father_ module_ add.php 位 于 配套 素材 包 的 ch21\manage\ 下 ,是 父 版 块 添加 页 面 。 具体 代码 
如 下 。 

<?php 

include "session.inc"; 

include "fun head.php"; 

head (" 父 版 块 添加 ") ; 

include "../inc/mysql.inc"; 

include "../inc/myfunction.inc"; 

$aa=new mysqlconn; 

$bb=new myfunction; 

$aa->link(""); 

$add tag=@$_GET['add tag']; 

if ($add tag==1){ 

$show_order=$_POST['show order']; 

$module name=$_POST['module name']; 

if ($show order=="" or $module name==""){ 

echo " 不 起 ， 您 添加 父 版 块 不 成 功 : 

<font color=red> 显 示 序 号 和 父 版 块 名 称 全 不 能 为 空 </font>! ==="; 

}else{ 

$query="insert into 

father module info (module name,show order) 
values ('$module name','$show order')"; 

$aa->excu ($query); 

echo "=== 蕉 喜 您 ， 添 加 父 版 块 添加 成 功 ! ==="; 

} 

?> 

<table width="100%" height="389" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 

<tbody> 
< 
<td width="20">&nbsp;</td> 
<td valign="top"><br /> 
<form action="?add tag=1" method="post" name="form]l" id="forml"> 
<table width="408" height="87" border="0" align="center" 

cellpadding="0" cellspacing="1" bordercolor="#FFFFFF" bgcolor="449ae8"> 





<tr bgcolor="#dcccccc"> 
<td width="94" height="25" bgcolor="e0eef5"><div align="right"> 
显示 序号 :</div></td> 
<td width="306" bgcolor="e0eef5"><input type="text" size="6" 
name="show_order" /> 


请 填写 一 整数 ， 如 : 1 
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<“/td> 
<HEr> 
<tr bgcolor="#dddddd"> 
<td height="25" bgcolor="#FFFFFF"><div align="right"> 父 版 块 名 
称 :</div></td> 


<td bgcolor="#FFFFFF"><input type="text" size="20" 
name="module name" /></td> 
EXEr> 


<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"><dqiv align="center"> 
<input name="submit" type="submit" value=" 提 交 " /> 
&nbsp; Enbsp; gnbsp’; gnbsp; gnbsp; gnbsp; 
<input name="reset" type="reset" value=" 重 置 " /> 
</div></td> 
</tr> 
</table> 
</form> 
<br /> 
<br /></td> 
<td width="20">&nbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
> 


文件 father_module_bj.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 父 版 块 编辑 页 面 。 具 体 代码 
如 下 。 

<?php 
include "session.inc"; 
include "fun head.php"; 
head (" 父 版 块 管理 ==>> 编 辑 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysqlconn; 
$bb=new myfunction; 
$aa->link(""); 
$module id=$_GET['module id']; 
$update tag=@$_ GET['update tag']; 
if ($update tag==1){ 
$show_order=$_POST['show order']; 
$module name=$_ POST['module name']; 

if ($show order=: 





"" or $module name==""){ 


=== 对 不 起 ， 您 编辑 父 版 块 不 成 功 : <font color=red> 





echo " 
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显示 序号 和 父 版 块 名 称 全 不 能 为 空 </font>1! 
}else{ 
$query=" 
'$show order 
' where id='$module id'"; 
$aa->excu ($query); 


echo "=== 共 喜 您 ， 添 加 父 版 块 添加 成 功 ! ==="; 
上 


update father module info set module name='$module name',show order= 


|! 
$query="select * from father module info where id='$module id'"; 


$rst=$aa->excu ($query); 
$module=mysqli _ fetch array($rst,MYSQL ASSOC); 
?> 
<table width="100%" height="389" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 

<tbody> 


<tr> 
<td width="20">gnbsp;</td> 


<td valign="top"><br /> 
?update tag=1&module id=<?php echo $module id?>" 






<form actio 


method="post" name="forml" id="forml"> 
<table width="408" height="87" border="0" align="center" cellpadding="0" 


cellspacing="1" bordercolor="#FFFFFF" bgcolor="449ae8"> 
<tr bgcolor="#dcccccc"> 
<td width="94" height="25" bgcolor="e0eef5"><div align="right"> 
显示 序号 :</div></td> 

<td width="306" bgcolor="e0eef5"><input type="text" size="6" 

name="show_order" value="<?php echo $module['show order']?>" /> 
请 填写 一 整数 ， 如 : 1 
.</td> 


</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" bgcolor="#FFFFFF"><div align="right"> 父 版 块 名 


称 :</div></td> 
<td bgcolor="#FFFFFF"><input type="text" size="20" name="module name" 


value="<?php echo $module['module name']?>" /></td> 


</tr> 
<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"><div align="center"> 





<input name="submit" type="submit" value=" 提 交 " /> 
&nbsp; gnbsp; gnbsp; gnbsp; gnbsp; gnbsp; 
<input name="reset" type="reset" value=" 重 置 " /> 
</div></td> 
区 WE 
</table> 
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</form> 
<br /> 
<br /></td> 
<td width="20">gnbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 


文件 father_module_list.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 父 版 块 添加 显示 页 面 。 具体 
代码 如 下 。 


<?php 
include "session.inc"; 
include "fun head.php"; 
head (" 父 版 块 管理 ") ; 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysqlconn; 
$bb=new myfunction; 
$aa->link(""); 
LLVVMV7M7M7 删 除 父 版 块 1111W1VV1V1VVV1111111111111111111 
$del tag=@$ GET['del tag']; 
if ($del tag==1){ 
$module id=$_GET['module id']; 
$query="delete from father module info where id='$module id'"; 
$aa->excu ($query); 
echo "== 恭 喜 您 ， 删 除 父 版 块 信息 成 功 ! ==<br />"; 
} 
111141411111 按 显示 顺序 查询 父 版 块 信息 表 /11WL111111111111111171/ 
$query="select * from father module info order by show order"; 
$rst=$aa->excu ($query); 
和 
<table width="100%" height="390" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">gnbsp;</td> 
<td valign="top"><br /><table width="80%" border="0" align="center" 
cellpadding="0" cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 
<td width="92" height="23" bgcolor="e0eef5"><div align="center"> 编 号 
</div></td> 
<td width="193" bgcolor="e0eef5"><div align="center"> 显示 序号 
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</div></td> 
<td width="368" bgcolor="e0eef5"><div align="center"> 父 版 块 名 称 
</div></td> 





<td colspan=" 
</tr> 
<?php 
Sm=07 
while($module=mysqli fetch array($rst,MYSQL RSSOC) ) { 
Sm++ 7 


" bgcolor="e0eef5"><div align="center"> 操 作 </div></td> 


A 
<td height="19" bgcolor="#FFFFFF"><div align="center"><?php echo 
$m;?></div></td> 


<td bgcolor="#FFFFFF"><div align="center"><?php echo 
$module['show order']?></div></td> 
<td bgcolor="#FFFFFF"><div align="center"><?php echo 


$module['module name']?></div></td> 
<td width="134" align="center" 
bgcolor="#FFFFFF"><a href="father module bj.php?module id= 
<?php echo $module['id'];?>"> 编 辑 </a></td> 
<td width="142" align="center" bgcolor="#FFFFFF"><a 
href="?del tag=l&module id= 
<?php echo $module['id']?>"> 删 除 </a></td> 
</tr> 
<?php }?> 
</table> 
</td> 
<td width="20">&nbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
2 


文件 son_module_add.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 子 版 块 添加 页 面 。 具 体 代码 

如 下 。 

<?php 

include "session.inc"; 

include "fun head.php"; 

head (" 子 版 块 添加 ") ; 

include "../inc/mysql.inc"; 

include "../inc/myfunction.inc"; 

$aa=new mysqlconn; 

$bb=new myfunction; 
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Saa->link(™™")? 

$add tag=@$ GET['add tag']; 

if ($add tag==1){ 

$father module id=$ POST['father module id']; 

$module name=$_ POST['module name']; 

$module cont=$_ POST['module cont']; 

$user name=$_POST['user name']; 
if ($father module id=="" or $module name=="" or $module cont==""){ 
echo "=== 对 不 起 ， 您 添加 子 版 块 不 成 功 : <font color=red> 隶 属 的 父 版 块 、 

子 版 块 的 名 称 和 简介 全 不 能 为 空 </font>! ==="; 
}else{ 
$query="insert into son module infol(father module id 

module name,module cont,user name) 

values ('$father module id','$module name','$module cont','$user name')"; 
$aa->excu ($query); 


= 恭喜 您 ， 子 版 块 添加 成 功 ! == 











"100%" height="389" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">&nbsp;</td> 
<td valign="top"><br /> 
<form action="?add tag=1" method="post" name="forml" id="forml"> 
<table width="408" height="139" border="0" align="center" 
cellpadding="0" 
cellspacing="1" bordercolor="#FFFFFF" bgcolor="449ae8"> 
<tr bgcolor="#dcccccc"> 
<td width="94" height="25" bgcolor="e0eef5"><div align="right"> 
隶属 的 父 版 块 :</div></td> 


<td width="306" bgcolor="e0eef5"><?php 
$bb->father module list("");?></td> 
</tr> 


<tr bgcolor="#dddddd"> 
<td height="25" bgcolor="#FFFFFF"><div align="right"> 子 版 块 名 
称 :</div></td> 


<td bgcolor="#FFFFFF"><input type="text" size="20" 
name="module name" /></td> 
</tr> 


<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle" bgcolor="#FFFFFF"> 
简介 :</td> 


<td bgcolor="#FFFFFF"><textarea name="module cont" 
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cols="42" rows="3"></textarea></td> 
<HEr> 
<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle" bgcolor="#FFFFFF"> 
版 主 用 户 名 :</td> 
<td bgcolor="#FFFFFF"><input type="text" size="20" 
name="user name" /> 
可 不 填 。</td> 
</Er> 
<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"><dqiv align="center"> 
<input name="submit" type="submit" value=" 提 交 " /> 
&nbsp; Enbsp; gnbsp’; gnbsp; gnbsp; gnbsp; 
<input name="reset" type="reset" value=" 重 置 " /> 
</div></td> 
</tr> 
</table> 
</form> 
<br /> 
<br /></td> 
<td width="20">&nbsp;</td> 
cAEr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
2 








文件 sonr_module_bj.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 子 版 块 编辑 页 面 。 具 体 代 码 如 


<?php 

include "session.inc"; 

include "fun head.php"; 

head (" 子 版 块 管理 >> 编 辑 ") ; 

include "../inc/mysql.inc"; 

include "../inc/myfunction.inc"; 
$aa=new mysqlconn; 

$bb=new myfunction; 

$aa->link(""); 

$module id=$_GET['module id']; 
$update tag=@$_GET['update tag']; 
if ($update tag==1){ 

$father module id=$ POST['father module id']; 
$module name=$_ POST['module name']; 
$module cont=$_POST['module cont']; 
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$user name=$_ POST['user name']; 

if ($father module id=="" or $module name=="" or $module cont==""){ 
echo "=== 对 不 起 ， 您 编辑 子 版 块 不 成 功 : <font color=red> 隶 属 的 父 版 块 、 

子 版 块 的 名 称 和 简介 全 不 能 为 空 </font>! == 
}else{ 

$query="update son module info 





set 
father module id='$father module id',module name='$module name',module cont 
='$module cont',user name 
='$user name' where id='$module id'"; 
$aa->excu ($query); 


= 恭喜 您 ， 编 辑 子 版 块 添加 成 功 ! ==="; 





echo " 
上 
$query="select * from son module info where id='Smodule id'"; 
$rst=$aa->excu ($query); 
$module=mysqli fetch array($rst,MYSQL ASSOC); 
?> 
<table width="100%" height="389" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">&nbsp;</td> 
<td valign="top"><br /> 
<form action="?update tag=1&module id=<?php echo $module id?>" 
method="post" name="forml" id="forml"> 
<table width="408" height="139" border="0" align="center" 





cellpadding="0" 
cellspacing="1" bordercolor="#FFFFFF" bgcolor="449ae8"> 
<tr bgcolor="#dcccccc"> 
<td width="94" height="25" bgcolor="e0eef5"><div align="right"> 
隶属 的 父 版 块 :</div></td> 
<td width="306" 
bgcolor="e0eef5"><?php 
$bb->father module list ($module['father module id']);?></td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" bgcolor="#FFFFFF"><div align="right"> 子 版 块 名 
称 :</div></td> 


<td bgcolor="#FFFFFF"><input type="text" size="20" 
name="module name" value="<?php echo $module['module name']?>" /></td> 
SCE 


<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle" bgcolor="#FFFFFF"> 


简介 :</td> 
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<td bgcolor="#FFFFFF"><textarea name="module cont" cols="42" 
rows="3"> 
<?php echo $module['module cont']?></textarea></td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="25" align="right" valign="middle" bgcolor="#FFFFFF"> 
版 主 用 户 名 :</td> 
<td bgcolor="#FFFFFF"><input type="text" size="20" 
name="Uuser name" value=" 
<?php echo $module['user name']?>" ea 
可 不 填 。</td> 
</tr> 
<tr bgcolor="#dddddd"> 
<td height="33" colspan="2" bgcolor="e0eef5"><div align="center"> 
<input name="submit" type="submit" value=" 提 交 " /> 
&nbsp; Enbsp; gnbsp; gnbsp; gnbsp; gnbsp; 
<input name="reset" type="reset" value=" 重 署 " /> 
</div></td> 
</tr> 
</table> 
</form> 
<br /> 
<br /></td> 
<td width="20">&nbsp;</td> 
eA 
</tbody> 
</table> 
<?php 
include "bottom.php"; 


文件 son_module list.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 子 版 块 显示 页 面 。 具 体 代 码 如 下 。 
<?php 

include "session.inc"; 

include "fun head.php"; 
head (" 子 版 块 管理 ") ; 

include "../inc/mysql.inc"; 

include "../inc/myfunction.inc"; 
$aa=new mysqlconn; 
$bb=new myfunction; 
$aa->link(""); 
4ML441147M11 删 除 子 版 块 111111V411V1V11V11111111111111111 
$del tag=@$ GET['del tag']; 
if ($del tag==1){ 

$module id=$_ GET['module id']; 
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$query="delete from son module info where id='Smodule id'"; 
$aa->excu ($query); 
echo "== 恭 喜 您 ， 删 除 子 版 块 信息 成 功 ! ==<br />"; 
} 
L11114111111111111/ 按 显示 顺序 查询 父 版 块 信息 表 // /1111111117 
$query="select * from father module info order by show order"; 
$rst=$aa->excu ($query); 
2 
<table width="100%" height="390" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
Er 
<td width="20">&nbsp;</td> 
<td vali top"><br /><table width="80%" border="0" align="center" 
cellpadding="0" cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 
<td width="74" height="23" bgcolor="e0eef5"><div align="center"> 显 示 
序号 </div></td> 
<td width="84" bgcolor="e0eef5"><div align="center"> 父 版 块 名 称 
</div></td> 
<td width="410" bgcolor="e0eef5"><div align="center"> 子 版 块 名 称 
</div></td> 
<td colspan="2" bgcolor="e0eef5"><div align="center"> 操 作 </div></td> 
</tr> 
<?php 
while($father module=mysqli fetch array($rst,MYSQOL ASSOC)){ 
?> 
EY 
<td height="19" bgcolor="#FFFFFF"><div align="center"> 
<?php echo $father module['show order']?></div></td> 
<td colspan="4" align="]left" valign="middle" bgcolor="#CCCCCC"> 
<?php echo $father module['module name']?></td> 








</tr> 
<?php 
/11/11/11 从 子 版 块 信息 表 中 按 id 顺序 查询 隶属 该 父 版 块 的 子 版 块 的 信息 /1/1//11111177 
$query="select - from son module info where 
father module id='".$father module['id']."" 
Order by id"; 
$rst2=$aa->excu ($query); 
$m=0; 
while($son module=mysqli fetch array($rst2,MYSQOL ASSOC)){ 
Sm+ 二 7 
i 
六 


<td height="19" bgcolor="#FFFFFF">&nbsp;</td> 
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<td align="center" valign="middle" bgcolor="#FFFFFF"><?php echo 
$m?></td> 
<td bgcolor="#FFFFFF"><?php echo $son module['module name']?></td> 
<td width="80" align="center" 
bgcolor="#FFFFFF"><a href="son module bj.php?module id= 
<?php echo $son module['id'];?>"> 编 辑 </a></td> 
<td width="80" align="center" bgcolor="#FFFFFF"><a 
href="?del tag=l&module id= 
<?php echo $son module['id']?>"> 删 除 </a></td> 
<?php }?> 
</tr> 
<?php }?> 
</table> 





</td> 
<td width="20">&nbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
六 区 


文件 user _list.php 位 于 配套 素材 包 的 ch21\manage\ 下 , 是 显示 所 有 用 户 的 页 面 。 具 体 代 码 如 下 。 


<?php 
include "session.inc"; 
include "fun head.php"; 
head ("所 有 用 户 "); 
include "../inc/mysql.inc"; 
include "../inc/myfunction.inc"; 
$aa=new mysqlconn; 
$bb=new myfunction; 
$aa->link(™™"); 
LMM4M11171M1 删 除 注册 用 户 1VV41VVVV4V1V1VV1W111111111111111 
$del tag=@$ GET[del tag]; 
if ($del tag==1){ 
$user id=@$_GET[user id]; 
$query="delete from user info where id='S$user id'"; 
$aa->excu ($query); 
echo "== 恭 喜 您 ， 删 除 注册 用 户 信息 成 功 ! ==<br />"; 
1 
L11111111111/ 从 用 户 信息 表 中 查询 所 有 用 户 /11111111111111711/ 
$query="select * from user info order by id desc"; 
?> 
<table width="100%" height="390" border="0" cellpadding="0" cellspacing="0" 
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bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width: 0">gnbsp;</td> 
<td valign="top"><br /> 
<table width="80%" border="0" align="center" cellpadding="0" 
cellspacing="0"> 
SE 
<td height="30" align="left" 
valign="middle"><?php $bb->page ($query,@$page id,@$add,20)?></td> 
> 
</table> 
<table width="80%" border="0" align="center" cellpadding="0" 
cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 








<td width="46" height="23" bgcolor="e0eef5"><div align="center"> 序 号 
</div></td> 
<td width="213" bgcolor="e0eef5"><div align="center"> 用 户 名 
</div></td> 
<td width="201" bgcolor="e0eef5"><div align="center"> 注册 时 间 
</div></td> 
<td width="188" bgcolor="e0eef5"><div align="center"> 最 后 登录 时 间 
</div></td> 
<td width="80" bgcolor="e0eef5"><div align="center"> 操 作 </div></td> 
</tr> 
<?php 
$rst=$aa->excu ($query); 
$m=0; 
while ($user=mysqli fetch array($rst,MYSQOL ASSOC)){ 
Smt++; 
> 
<tr> 


<td height="19" bgcolor="#FFFFFF"><div align="center"><?php echo 
@$m; ?></div></td> 


<td bgcolor="#FFFFFF"><div align="center"><?php echo 
$user['user name'] ?></div></td> 

<td bgcolor="#FFFFFF"><div align="center"><?php echo 
$user['timel']?></div></td> 

<td align="center" bgcolor="#FFFFFF"><?php echo $user['time2']?></td> 





<td align="center" bgcolor="#FFFFFF"><a href="?del tag=l&user id= 
<?php echo $user['id']?>"> 删 除 </a></td> 
</tr> 
<?2php }?> 
</table> 
<table width="80%" border="0" align="center" cellpadding="0" 








PHP+7ySQL 动态 网 站 开发 从 入 门 到 精通 (视频 教学 版 》 





cellspacing="0"> 
<tr> 
<td height="30" align="right" valign="middle"> 
<?php 
$query="select * from user info order by id desc"; 
$bb->page ($query, @$page id, @$add,20); 
?></td> 
</tr> 
</table></td> 
<td width="20">gnbsp;</td> 
</tr> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
?> 


文件 user js.php 位 于 配套 素材 包 的 ch21\manage\ 下 ， 是 用 户 的 检索 页 面 。 具 体 代码 如 下 。 


<?php 

include "session.inc"; 

include "fun head.php"; 

head (" 用 户 检 索 ") ; 

include "../inc/mysql.inc"; 

include "../inc/myfunction.inc"; 

$aa=new mysqlconn; 

$bb=new myfunction; 

$aa->link(""); 

LLMVVVMMMVM7 删 除 用 户 11 V4VVV1YVVV1V11111111111111111171 
$del tag=@$_GET[del tag]; 

if ($del tag==1){ 

$del id=@$_GET[del id]; 

$query="delete from user info where id='".$del id."'"; 








$aa->excu ($query); 
echo "== 恭 喜 您 ， 删 除 用 户 信息 成 功 ， 请 继续 ! ==<br />"; 
} 
ER ON RANA EN A Rd dd 
$user name=@$_POST [user name]; 
> 
<table width="100%" height="390" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">gnbsp;</td> 
<td valign="top"><br /> 
<table width="70%" border="0" align="center" cellpadding="0" 
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cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 
<form id="forml" name="forml" method="post" action="?"> 
<td height="23" bgcolor="e0eef5"><div align="center"> 
<input type="text" name="user name" size="16" value=" 
<?php echo $user name?>" />gnbsp;&nbsp; gnbsp; gnbsp; 
<input type="submit" name="Submit" value=" 提 交 " /> 


</div></td> 

</form> 
/ET 

E> 

<td height="19" align="center" bgcolor="#FFFFFF"> 
<?php 
if ($user name==""){ 

echo "请 输入 您 要 检索 的 用 户 名 ， 点 提交 查询 ! "; 
}else{ 


$query="select * from user info where user name='$user name'™"; 
$rst=$aa->excu ($query); 
if (mysqli num rows ($rst)==0){ 
echo "很 抱歉 ， 系 统 没有 检索 到 您 要 查找 的 用 户 ! "; 
}else{ 
$user=mysqli fetch array($rst,MYSQL ASSOC); 
<table width="100%" border="0" cellspacing="2" cellpadding="0"> 
<tr> 
<td width="29%" height="20" align="right" bgcolor="#dddddd"> 用 户 
名 :</td> 
<td width="71%" align="left" bgcolor="#dddddd"><?php echo 
$user['user name']?></td> 
</tr> 
<tr> 
<td height="20" align="right" bgcolor="#dddddd"> 登 录 口 令 :</td> 
<td align="]left" bgcolor="#dddddd"><?php echo 
$user['user pw']?></td> 
</tr> 
<tr> 
<td height="20" align="right" bgcolor="#dddddd"> 注 册 时 间 :</td> 
<td align="left" bgcolor="#dddddd"><?php echo 
$user['timel']?></td> 
</tr> 
<tr> 





<td height="20" align="right" bgcolor: 
<td align="left" bgcolor= 
$user['time2']?></td> 
</tr> 


"#dddddd"> 最 后 登录 时 间 :</td> 
#daddddd"><?php echo 








PHP+MySOL 局 


文件 user_ pw_change.php 位 于 配套 素材 包 的 ch21manage\ 下 ， 是 管理 员 密码 修改 页 面 。 具 体 代 
码 如 下 。 
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Srst=S$aa->excu(Squery) 7 
if (mysqli num rows ($rst)==0){ 


您 输入 的 旧 密 码 不 正确 ,请 重新 输入 !==="; 





echo "= 
}elsef{ 
$query="update manage user info set 
User pw="'$pw newl' where user name='$_SESSION[manage name] '"; 
$aa->excu($query); 


echo "=== 茶 喜 您 ,您 的 登录 密码 修改 成 功 != 





避 一 


<table width="100%" height="390" border="0" cellpadding="0" cellspacing="0" 
bgcolor="f0f0f0"> 
<tbody> 
<tr> 
<td width="20">&nbsp;</td> 
<td valign="top"><br /> 
<form id="forml" name="forml" method="post" action="#"> 
<table width="60%" border="0" align="center" cellpadding="0" 
cellspacing="1" bgcolor="449ae8"> 
<tr bgcolor="#cccccc"> 
<td width="27%" height="23" align="right" bgcolor="e0eef5"> 用 户 名 :</td> 








<td width="73%" align="left" bgcolor="e0eef5"> 
<?php echo $_SESSION [manage name]?></td> 
</Er> 
<tr> 


<td height="19" align="right" bgcolor="#FFFFFF"> 原 口令 :</td> 
<td align="left" bgcolor="#FFFFFF"><input type="text" name="pw_old" 
size="16" /></td> 


</tr> 
<tr> 
<td height="19" align="right" bgcolor="#FFFFFF"> 新 密码 :</td> 
<td align="]left" bgcolor="#FFFFFF"><input type="text" 
name="pw_newl" size="16" /></td> 
</tr> 
<tr> 
<td height="19" align="right" bgcolor="#FFFFFF"> 再 次 新 密码 :</td> 
<td align="1left" bgcolor="#FFFFFF"><input type="text" 
name="pw_new2" size="16" /></td> 
HEE 
<tr> 


<td height="19" colspan="2" align="center" bgcolor="#FFFFFF"> 
<input type="submit" name="tijiao"” value=" 提 交 " /> 
&nbsp; gnbsp; gnbsp; 
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<input type="reset" name="Submit2" value=" 重 置 " /></td> 
xr 
</table> 
</form> 
</td> 
<td width="20">gnbsp;</td> 
到 /ETE> 
</tbody> 
</table> 
<?php 
include "bottom.php"; 
?> 


成 功 登 录 到 网 站 后 台 管 理 系统 的 效果 如 图 21-9 所 示 。 


单 击 页 面 左 侧 的 【论坛 版 块 管理 】 选 项 ， 即 可 在 展开 的 列表 中 查看 版 块 管理 操作 ， 如 图 21-10 
所 示 。 


| 浊 
用户 admin 
有 从 :admin 


00 


二 共和 可 其 分 四 于 专区 村 到 旭 ， 世 折 据 竺 二 和 理由 区 分 丙 下 子 电 六 :所 有 用 户 和 产检。 其 
得 于 所 寺 加 ， 子 扳 所 生理 其 中 区 志 当 二 三 版 沁 。。 中 他 用 户 近 用 户 汪 了 的 先导 了 分 页 | 用 户 从 
折扣 了 以 实现 二 兴起 的 灵 折 志和 开 岂 的 措 加 ; 关上 块 的 。。 他 是 由 各 各 只 由 入 要 查 诡 允 论 二 用 户 的 用 户 才 ， 系 纺 
管理 和 了 新 维和 理 认 聘 本 兴 芭 区 拓 具 和 地 扳 纪 奖 通过 下 所 放 查 这 风 户 兹 相信 息 ， 并列 出 ， 而且 生理 
障 辆 等 z 能 - 届 也 可 避 在 查 许 绩 同 户 后 该 用 户 、 


[sse | 


未 管理 报信 本子 情 闭 得 更 吉他 各 理 .其 大 六 提供 了 本 论 世 的 质 号 、 拓 相关 有 、 读 计 堵 作 
中 策 丙 六 提供 了 管理 月 现 交 全 和 夺 ,得 必 全 注入 碌 人 以及 技术 区 持 竺 全 

宅 码 和 而 给 新 志 ; 从 子 香 是 直 举 入 论 二 站 主 愉 面 ， 

人 与 注册 周记 所 不 必 的 是 在 论坛 和 人 类 和 同和 揽 

后 面霜 多 了 一 个 扩 取得 ， 可 沪 让 入 大池 了 夫 时 了 





图 21-9 后 台 管 理 系统 主页 面 图 21-10 【论坛 版 块 管理 】 列 表 


单 击 【 父 版 块 添加 】 选 项 ， 即 可 在 右 侧 的 窗口 中 输入 显示 序号 和 父 版 块 名 称 ， 然 后 单 击 【 提 
交 】 按 钮 ， 如 图 21-11 所 示 。 



































加 匡 




















图 21-11 添加 父 版 块 图 21-12 添加 父 版 块 成 功 提示 信息 
刷新 论坛 的 主页 面 ， 即 可 看 到 新 添加 的 父 版 块 ， 如 图 21-13 所 示 。 
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在 后 台 管 理 主页 面 的 【论坛 版 块 管理 】 列 表 中 ， 单 击 【 父 版 块 管理 】 选 项 ， 即 可 进入 父 版 块 
管理 页 面 中 ， 如 图 21-14 所 示 。 用 户 可 以 编辑 和 删除 存在 的 父 版 块 。 


迅捷 BBS 系统 



































21-13 ”查看 父 版 块 21-14 编辑 父 版 块 
在 后 台 管理 主页 面 的 【论坛 版 块 管理 】 列 表 中 ， 单 击 【 子 版 块 添加 】 选 项 ， 即 可 进入 子 版 块 
添加 页 面 ， 如 图 21-15 所 示 。 用 户 输入 相关 信息 后 ， 单 击 【提交 】 按钮 即 可 。 
刷新 论坛 的 主页 面 ， 即 可 看 到 新 添加 的 子 版 块 ， 如 图 21-16 所 示 。 


迅捷 BBS 系统 





[EE 
了 对 各 数 :0 会 员 各 娄 :1 欢 多 新 全 月 :a2 


























| 
618 年 十 月 从 拼车 计划 | 























可 不 填 。 


























图 21-15 添加 子 版 块 图 21-16 查看 添加 的 子 版 块 


单 击 页 面 左 侧 的 【论坛 用 户 管理 】 选 项 ， 即 可 在 展开 的 列表 中 查看 用 户 管理 操作 ， 如 图 21-17 
所 示 。 
单 击 【 所 有 用 户 】 选 项 ， 即 可 在 右 侧 的 窗口 中 查看 论坛 的 用 户 ， 如 图 21-18 所 示 。 
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[下 一 页 第 ! 页 , 共 ! 页 





序号 用 户 名 注册 时 间 最 后 登录 时 间 操作 
论坛 用 户 管理 多 | 


aa 2016-06-08 04:11:28 a 删除 
ET- 页 六 砚 项 
图 21-17 【论坛 用 户 管理 】 列 表 图 21-18 【所 有 用 户 】 页 面 
在 后 台 


管理 主页 面 的 【用 户 版 块 管理 】 列 表 中 ， 单 击 【用户 检索 】 选 项 ， 进 入 用 户 检索 页 面 ， 
输入 用 户 名 后 ， 单 击 【 提 交 】 按 钮 ， 即 可 显示 用 户 的 具体 信息 ， 如 图 21-19 所 示 。 


在 后 台 管理 主页 面 中 ， 单 击 页 面 左 侧 的 【安全 管理 】 选 项 ， 即 可 在 展开 的 列表 中 管理 密码 和 
帖子 操作 ， 如 图 21-20 所 示 。 


网 冯 加 全 管理 系 给， 






































|aaa | 配 和 
用 户 名 : aas 
熙 录 口令 : 123456 
注册 时 间 : 2016-06-08 04:11:28 
最后 登录 时 间 : 2016-06-17 02;58;01 
山 除 此 用 户 


























图 21-19 用 户 检索 页 面 


图 21-20 【安全 管理 】 列 表 
单 击 【密码 更 改 】 选 项 ， 即 可 在 右 侧 的 页 面 中 修改 用 户 的 密码 ， 如 图 21-21 所 示 。 





用 户 名 : | aas 
原 口令 : 
新 密码 : 
再 次 新 密 
玛 : 
































[E 委 | 
图 21-21 更 改 用 户 密码 页 面 
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